选择方案的选择

  1. 单线程更新UI
  2. 多线程更新UI

从问题本身考虑就两个方案不是单线程就是多线程。

下面是个人根据具体情况分析,如果有什么不对的地方,欢迎指正。

从开发效率来看,开发一个 单线程UI 库,会显得非常容易,而且,每个控件的运行效率肯定会比多线程的效率高,比如我们单线程可以使用HashMap,多线程就需要使用JUC 框架下的类库了,这个效率肯定比 HashMap低很多,这样就很好理解。编写一个多线程的UI库,很可能每个控件,都会加锁,控件本身效率就低了,但是这样还不够 ,后面会解释。

还有一个简单方案,就是对真个UI库,加锁,而不是具体某个控件,就是确保同一时刻,只能有一个线程,对整个UI系统更新,这个已经有点单线程更新UI的意思了 。但是锁的粒度会很大,如果一个页面100个控件,相当于每个控件都加锁了。

这个方案实现起来倒是不复杂,只需要设计一个boolean变量就可以,任何线程需要更新UI 都会访问这个变量获取锁,这个方案会造成所有的线程都竞争同一把锁,单从运行效率分析,应该是很高的,但是这个竞争特别激烈,可能造成的问题就是,事件响应不够及时,

单线程更新UI方案简单成熟

单线程更新UI方案,从上面的分析来看,优势就很明显,整体设计可能是最简单的,每个控件的设计只需要考虑单线程运行就可以,完全不必关系其他线程更新UI。

而且这套方案非常成熟,在Android 之前,swing qt windows 几乎绝大部分图形界面api 都会使用这个单线程方案。

从执行效率看

前面说了,如果一个加锁的api 和不加锁的api 比较,那肯定不加锁效率高对吧,但是,这么说确实很笼统,如果合理设计一套多线程更新ui 的库,整体性能未必会比单线程差,只是想实现这样一套系统的复杂程度,可能不只是翻倍那么简单,设计越复杂,带来的问题是 潜在bug 可能会多,但是这些,在设计ui系统 的时候未必是这样考虑的,如果业务复杂,效果会更好,那么我相信大部分企业还是会设计一个复杂的系统的。

综合考虑?

多线程更新UI,不管如何设计都会绕不开一个问题,就是竞争,而这个竞争,是整个UI系统的,而不是单独一个控件,大部分情况下,一个线程可能同时更新的是过个控件,而要确保我一次更新的所有控件是同步更新的,所以要保证这个逻辑,其实我们就要确保一个问题,同一时刻。永远只允许一个线程去更新UI。不能保证这一点,就会造成业务逻辑可能各种问题,甚至各种死锁。

既然同一个时刻只能一个线程更新,那设计成单线程是不是就更好呢,到这里,其实还是不够全面的,还有个因素就是事件相应。如果多线程更新的情况下,其实这个是不容易实现的, 反而单线程,就好实现一些。

总结

通过分析总结几个点。

1.一般UI还是要保证同一时刻只有一个线程在更新,所以效率不会更高。
2.多线程更新UI实现上会复杂一些,Java的内部人员发布过文章也说过这个几乎不可实现。
3.从响应速度角度分析,单线程可以设计出更好的响应速度的api
4.单线程更新,也是一个被证明效果非常好的方案。

从过个角度分析 Android 为什么设计只有主线程更新UI 都是最好的选择。

不过回答这个问题需要理解的不全是结论,而是对这个问题,和图形界面开发的理解。

如果说效率高,安全,也需要回答出来为什么。这些不是凭空说的。真的效率高吗?高在哪里?都需要说清楚,可能会有不正确的地方。但是只要把需要考虑的点表达清晰就好

引用
负责Swing开发的一个大师的一篇博客《Multithreaded toolkits: A failed dream?》

也有人说单新ui 效率会高,因为多线程会加锁。如果有人能把这个细节解释清楚呢,希望留言。因为正常设计也只是锁更新那一行代码而已,我的总结就是效率不分伯仲,希望大家探讨吧。

更多 Android 知识点和面试题尽在GitHub,大家可以自行查阅

GitHub地址:
https://github.com/733gh/Android-T3

面试题:Android 为什么设计只有主线程更新UI相关推荐

  1. 为什么Android必须在主线程更新UI?

    为什么Android必须在主线程更新UI? 站在各位大牛的肩膀上,谢谢! 正常情况下,Android需要在UI线程更新UI,然鹅,在特殊情况下,子线程也能更新UI不在讨论之列,可参考Android中子 ...

  2. 为什么 Android 必须在主线程更新 UI ?

    点击蓝字 关注我们 为什么Android必须在主线程更新UI? 站在各位大牛的肩膀上,谢谢! 正常情况下,Android需要在UI线程更新UI,然鹅,在特殊情况下,子线程也能更新UI不在讨论之列,这篇 ...

  3. 真的必须要在主线程更新UI吗?

    一般UI更新都会调用requestLayout 或者invalidate, 自定义view 也要如此 ???. @android.view.RemotableViewMethod public voi ...

  4. [转]Android限制只能在主线程中进行UI访问的实现原理

    目录 Android限制只能在主线程中进行UI访问 Thread的实现 Android Thread 的构造方法 Android Thread 的start()方法 如何在我们自己的代码中去检测当前T ...

  5. android 不能在子线程中更新ui的讨论和分析

    问题描述 做过android开发基本都遇见过 ViewRootImpl$CalledFromWrongThreadException,上网一查,得到结果基本都是只能在主线程中更改 ui,子线程要修改 ...

  6. Android为什么不能在子线程更新UI

    Android为什么不能在子线程更新UI Android为什么不能在子线程更新UI? 如果不做这个校验,是不是我也可以正常在子线程更新UI 但是google为什么要这样去设计呢 ViewRootImp ...

  7. android remoteviews 设置背景,Android通过RemoteViews实现跨进程更新UI示例

    一.概述 前面一篇文章Android通过AIDL实现跨进程更新UI我们学习了aidl跨进程更新ui,这种传统方式实现跨进程更新UI是可行的,但有以下弊端: View中的方法数比较多,在IPC中需要增加 ...

  8. 【Android 异步操作】Handler ( 主线程中的 Handler 与 Looper | Handler 原理简介 )

    文章目录 一.主线程中的 Handler 与 Looper 二.Handler 原理简介 一.主线程中的 Handler 与 Looper Android 系统中 , 点击图标启动一个应用进程 , 就 ...

  9. android view只能在主线程操作

    接触android时间不长,今天在写程序的时候想要根据数据变化改变RecyclerView列表的程序,在改变数据后,更新界面时报如下的错误:Only the original thread that ...

  10. OC 主线程刷新UI

    在使用OC进行开发的时候,如果遇到报Thread线程错误(崩溃),那可能就是在进行UI操作的时候没有放在主线程中导致的! 在OC中将UI操作切换到主线程进行的方法如下: if ([NSThread i ...

最新文章

  1. 请关注你的网站跳出率
  2. 推荐一个算法/数据结构 可视化(Data structure Visualization) 网站
  3. 玩转服务器(华为云)—环境安装(jdk安装,tomcat安装)
  4. mysql hicharts_PHP怎么调用Mysql的数据给Highcharts
  5. 8皇后以及N皇后算法探究,回溯算法的JAVA实现,非递归,数据结构“栈”实现
  6. 前端工作面试问题(下)
  7. IE8无法调试?IE进入不了调试状态
  8. 到2025年将保持不变的热门流行技术
  9. python编程入门教学-史上最全Python编程基础入门教程
  10. python分数类_利用标准库fractions模块让Python支持分数类型的方法详解
  11. 有关i386和i686
  12. 配置JDK、Tomcat环境、DNK环境
  13. 安卓搭建虚拟服务器,安卓手机搭建云服务器
  14. 隆重纪念鲁宾逊诞辰,不走样,不离谱
  15. Combining Sketch and Tone for Pencil Drawing Production 论文阅读(1)
  16. GS1011无线模块的使用简介。
  17. 原生安卓解决WiFi网络受限以及修改NTP服务器
  18. 利用Java实现反向代理
  19. 后台服务被恶意脚本访问
  20. 实验8-2-10 IP地址转换

热门文章

  1. Threejs中使用A*算法寻路导航,Threejs室内室外地图导航
  2. 精益技术简历之道——改善技术简历的47条原则
  3. Python之进制转换大全详解
  4. 函数式编程Haskell初探
  5. 我的世界java版本试玩_我的世界Minecraft Java版17w49a发布
  6. C语言:输出菱形图案
  7. uc手机浏览器 手机模拟_UC浏览器开发者版调试手机页面
  8. 浪潮激荡大时代,存储起航新十年
  9. 酷软正在连接服务器,蜗牛星际:我的B款双网口机箱PVE+爱快+LEDE 双软路由 保姆级教程...
  10. python计算直角三角形斜边上的中线_怎么证明直角三角形斜边上的中线