android Handler應設為static
阿新 • • 發佈:2018-12-23
android開發中,使用Lint檢測時會提示這麼一句話 : This Handler class should be static or leaks might occur。意為handler應用static修飾否則容易發生記憶體洩漏。
ADT20有這麼一個變化:Look for handler leaks: This check makes sure that a handler inner class does not hold an implicit reference to its outer class。意為handler不應包括外部類的隱式引用。
擴充套件開來就是:同一個執行緒下的handler共享一個looper物件,訊息中保留了對handler的引用,只要有訊息在佇列中,那麼handler便無法被回收,如果handler不是static,那麼使用Handler的Service和Activity就也無法被回收,即便它們的ondestroy方法被呼叫。這就可能導致記憶體洩露。當然這通常不會發生,除非你傳送了一個延時很長的訊息。
ADT20有這麼一個變化:Look for handler leaks: This check makes sure that a handler inner class does not hold an implicit reference to its outer class。意為handler不應包括外部類的隱式引用。
擴充套件開來就是:同一個執行緒下的handler共享一個looper物件,訊息中保留了對handler的引用,只要有訊息在佇列中,那麼handler便無法被回收,如果handler不是static,那麼使用Handler的Service和Activity就也無法被回收,即便它們的ondestroy方法被呼叫。這就可能導致記憶體洩露。當然這通常不會發生,除非你傳送了一個延時很長的訊息。
但把hanlder新增為static後,會發現在handler中呼叫外部類的方法和成員變數需要它們都定義為final,這顯然是不大可能的。這裡建議在你的Service或Activity中的增加一個內部static Handler類,這個內部類持有Service或Activity的弱引用,這樣就可以解決final的問題。
static class IncomingHandler extends Handler { private final WeakReference<UDPListenerService> mService; IncomingHandler(UDPListenerService service) { mService = new WeakRference<UDPListenerService>(service); } @Override public void handleMessage(Message msg) { UDPListenerService service = mService.get(); if (service != null) { service.handleMessage(msg); } } }
static class MyHandler extends Handler { WeakReference<PopupActivity> mActivity; MyHandler(PopupActivity activity) { mActivity = new WeakReference<PopupActivity>(activity); } @Override public void handleMessage(Message msg) { PopupActivity theActivity = mActivity.get(); switch (msg.what) { case 0: theActivity.popPlay.setChecked(true); break; } } }; MyHandler ttsHandler = new MyHandler(this); private Cursor mCursor; private void test() { ttsHandler.sendEmptyMessage(0); } }
static class MHandler extends Handler {
WeakReference<OuterClass> outerClass;
MHandler(OuterClass activity) {
outerClass = new WeakReference<OuterClass>(activity);
}
@Override
public void handleMessage(android.os.Message msg) {
OuterClass theClass = outerClass.get();
switch (msg.what) {
case 0: {
//使用theClass訪問外部類成員和方法
break;
}
default: {
Log.w(TAG, "未知的Handler Message:" + msg.what);
}
}
}
}