AndroidDev 板


LINE

※ 引述《ntuleo (里欧)》之铭言: : 我们都知道要开一个thread去改UI的话是不行的,需要用handler机制把thread用 : sendmessage的方式回call main thread的handle message才能修改 : 这边有个疑问是 : 这样跟直接用method在main thread中修改UI有什麽差异呢? : 因为用handler新开的thread虽然是在後台跑 : 但是回call回来还是block住main thread不是吗? 这样跟用method有什麽不同呢? 不错不错。 你有在思考为什麽Android Framework不允许你在main thread之外的thread操作UI。 很多人其实搞不清楚这是怎麽一回事, 所以就会有一些倒因为果的回答,比如说ANR或阻塞之类的。 就好像你问人为什麽要吃东西,大家都回答因为肚子饿啊之类的回答。 这算是答案吗? 若是单纯要说有回答,是的,是有回答。 但这回答有意义吗? 不过这是典型台湾教育的人会出现的想当然尔。唉… 好的,继续回答标题问的这个问题。 现代的UI Framework通常会设计为操作UI只能在某一个特定的thread,我们通常会叫它UI thread。这里要厘清一下,我在这里说的UI thread和main thread语意上不一定是同一个thread。 WTF? 因为我指的不仅仅是Android Framework,而是指现代的UI Framework设计。只是Android Framework让main thread 成了UI thread。所以只写过Android的人会以为在其他系统上,main thread 就是UI thread。不是!是Android选择了这样的设计。你要我举main thread不是UI thread的Framewor。OK,Java标准的UI Framework,叫swing,main thread就不是UI thread。 厘清了这个观念後,接下来的问题是,为什麽现代的系统都要设计UI只能跑在单一thread上?不能让很多个thread都操纵UI吗? 不行。因为不这样设计会容易 deadlock。 为什麽? 这要分两方面讲。 第一个概念, 如果有两个thread写程式时上锁的顺序, thread 1是 拿到Lock A再来是 拿Lock B。 而thread 2 是 拿到Lock B 再来是拿 Lock A。 这样有可能thread 1 拿到Lock A, 这时thread 2拿到Lock B。 完蛋了,情况变成是thread 1永远拿不到Lock B, thread 2永远拿不到Lock A,产生了deadlock。 也就是多执行绪程式很重要的一条, 不同执行绪上锁的顺序要一致。 第二个概念 我们电脑系统的UI运作可以大概这样分层 App 应用程式 UI Framework 框架 OS 作业系统 HW 硬体 你写程式更改UI时程式是从APP>>UI Framework>> OS >> HW 而你写某个UI元件被触摸到时的反应是 HW>>OS>>UI Framework>>APP 嗯,两者方向相反。 好了今天要是这两者跑在不同thread上,而程式要取得某两个lock,lock A,lock B。 可能会有这样子的情况你写程式更改UI时程式是从 APP>>UI Framework part 1>>拿lock A>>UI Framework part 2>>拿lock B>>UI Framework part 3>>OS >> HW 而按钮触发实的反应执行时是 HW>>OS >>UI Framework part a >>拿lock B >>UI Framework part b>>拿lock A>>UI Framework part c>>APP 刚好满足了deadlock的条件 这就是为什麽UI要限制在单ㄧthread ,我们通常称呼为UI thread上执行。 你又会问那要是UI Framework设计为多执行绪会如何? 嗯,那你要很聪明,又很小心,很了解UI内部运作的细节来避开死锁。 但是要是死锁会很难侦错,因为死锁有时会发生有时不会发生。 而以前有人这样设计系统的情况是,没人读UI Framework设计者的说明档案和提醒,写程式的人遇到死锁时只是骂UI Framework设计的人是白痴,设计很烂。所以设计UI Framework现在都流行把UI限制在专门的thread上跑。 大概4酱。 读到这个问题很久了,只是我很懒得回答,因为要写这麽多。而且我当下还是只用手机写,两年了,我终於断断续续写完了。 这篇文章送给认真思考这个问题的你。 --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 114.43.131.117
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/AndroidDev/M.1516385589.A.D57.html
1F:→ cha122977: 另外UI视情况会故意掉祯 也不适合一般的function call 01/20 02:30
2F:→ kuangjc5566: 我不懂function call和UI thread有什麽关系? 01/20 02:56
3F:→ kuangjc5566: function call一定会执行到,不是写在Listener里就不 01/20 02:59
4F:→ kuangjc5566: 一定会执行,掉frame是别的层面的机制吧? 01/20 02:59
5F:→ lnmlee: 就跟军舰的武器官 统一掌管武器发射概念一样 01/20 22:51
6F:→ y3k: UI Thread九成九是同一个避免画面撕裂或当机之类的事 01/21 01:04
7F:→ y3k: 这是我自己的理解 至於dead lock这问题真没想过XD 01/21 01:24
8F:推 ininmm: 受教了 自己还没有从这个角度思考过 01/21 02:17







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:e-shopping站内搜寻

TOP