首先,UI控件不是线程安全的,如果多线程并发访问UI控件可能会出现不可预期的状态
那为什么系统不对UI控件的访问加上锁机制呢?
缺点有两个:
- 加上锁机制会让UI访问的逻辑变复杂;
- 锁机制会降低UI访问的效率,因为锁机制会阻塞某些线程的执行;
将于这两个缺点,最简单且高效的方法就是采用单线程模型来处理UI操作,所以源码ViewRootImpl中会有对线程的一个判断,代码如下:
frameworks/base/core/java/android/view/ViewRootImpl.java
void checkThread() {
if (mThread != Thread.currentThread()) {
throw new CalledFromWrongThreadException(
"Only the original thread that created a view hierarchy can touch its views.");
}
}
对于开发者来说也不是很麻烦,只是通过handler切换一下UI访问的执行线程即可。