→ hellogg1: 所以你不能在main thread做耗時的事情否則會ANR 03/20 17:07
→ issuemylove: UI的修改前,可能會有大量的計算 大量計算跑在main 03/20 17:28
→ issuemylove: 下略 你懂的 03/20 17:28
→ ntuleo: 大量計算開thread,修改UI再call method 03/20 19:42
→ ntuleo: 這樣不使用handler也可以達到handler改UI的效果不是嗎? 03/20 19:43
→ ntuleo: 不了解的點是兩種方法都會block main thread,那為什麼需要 03/20 19:47
→ ntuleo: 用比較麻煩的handler呢? 03/20 19:47
推 sdyy: 怎麼會一樣 例如你要載入一張網路圖片 把圖片載好花1秒 03/20 20:32
→ sdyy: 用main thread跑 你這一秒都被卡住 而另開thread 則只要指定 03/20 20:32
→ sdyy: 載好的圖片 記憶體都已擺好也就不會block到其他UI畫面 03/20 20:33
→ corrupt003: call method 在thread 底下做的話,還是跑在thread阿 03/20 20:43
→ corrupt003: 會用handler是因為一般情形下handler是綁ui thread 03/20 20:47
→ ssccg: call回來是在main thread的message queue上排程,不會直接 03/20 20:48
→ ssccg: block main thread,會block就是你用錯了 03/20 20:48
→ ssccg: handler是把message queue包裝起來用,跟開thread是兩回事 03/20 20:49
→ corrupt003: 所以有複雜計算在thread做,做完需要改ui時用handler 03/20 20:51
→ corrupt003: ,handler裡 call method才會在 ui thread 更新ui 03/20 20:51
→ ssccg: 你看起來跟thread不太熟,直接call method是在同一個thread 03/20 20:52
→ ntuleo: 感謝大家,我目前的理解是這樣的 03/20 21:57
→ ntuleo: handler誕生的主要原因是主線程要和子線程溝通用的 03/20 21:57
→ ntuleo: 一般thread做不到這一點 03/20 21:57
→ ntuleo: 所以比較heavy的工作放在thread做,要改ui再用handler 03/20 21:57
→ ntuleo: 通知main thread修改 03/20 21:58
→ ntuleo: 但今天如果只是簡單的setText,那其實直接call就可以了 03/20 21:58
→ ntuleo: 開thread再用handler call和直接call在這是沒有區別的 03/20 21:58
→ ntuleo: 因為中間沒有複雜的運算 03/20 21:58
→ qweqweqweqwe: 是阿.. 所以這種就直接setText 就可以了阿.. 03/20 22:00
→ ssccg: 有什麼不同你試一下就知道,只有在main thread才可以改UI 03/20 22:26
→ ssccg: 直接call你會得到一個CalledFromWrongThreadException 03/20 22:33
→ ckvir: 回call回來又不會block住 03/22 03:10
→ KeySabre: main thread已經很忙,要更新UI,又要處理touch event、 03/23 18:08
→ KeySabre: key event等,如果用來處理其他事情,使得畫面無法即時 03/23 18:08
→ KeySabre: 更新,觸控事件無法即時處理,操作就會卡頓,人眼認為fp 03/23 18:08
→ KeySabre: s 30是順暢;另外我記得系統每16ms會draw一次,阻礙到就 03/23 18:08
→ KeySabre: 會感覺不順暢。Android有ANR機制保護,可讓使用者強制 03/23 18:08
→ KeySabre: 關閉程序,避免main thread被惡意佔用使得手機被綁架。 03/23 18:08
→ KeySabre: 另外broadcast receiver, service等也要注意,他們在系 03/23 18:08
→ KeySabre: 統內也有對應的回應時間控制。 03/23 18:08
→ KeySabre: Handler是Android提供讓你做非同步調用的機制所含的一 03/23 18:23
→ KeySabre: 個類別,大致上就是你可以開一個thread然後放Looper.pre 03/23 18:23
→ KeySabre: pare(),Looper會給這個thread一個message queue並且用 03/23 18:23
→ KeySabre: 迴圈去取,Handler必須與Looper搭配,當有message時就會 03/23 18:23
→ KeySabre: 發到Handler的handleMessage()。Handler的無參數建構子 03/23 18:23
→ KeySabre: 會用當前thread的looper,所以你在main thread創handler 03/23 18:23
→ KeySabre: ,就能利用main thread本來就有的looper,當你從其他thr 03/23 18:23
→ KeySabre: ead發送訊息給這個handler時,最終就可以在main thread 03/23 18:23
→ KeySabre: 處理這個訊息。如果要給別的thread一個handler,用法前 03/23 18:24
→ KeySabre: 面說過了,不然也可直接利用HandlerThread這個類別。 03/23 18:24