Создание потока в ViewRootImpl.java
Я пытаюсь создать поток с петлителем и обработчиком в ViewRootImpl.java, но я получаю эту ошибку:
02-03 14:04:14.266 884 884 E AndroidRuntime: java.lang.NullPointerException: Attempt to invoke virtual method 'boolean android.os.Handler.sendMessage(android.os.Message)' on a null object reference
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1344)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1150)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6076)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.view.Choreographer$CallbackRecord.run(Choreographer.java:858)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.view.Choreographer.doCallbacks(Choreographer.java:670)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.view.Choreographer.doFrame(Choreographer.java:606)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:844)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:739)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:95)
02-03 14:04:14.266 884 884 E AndroidRuntime: at android.os.Looper.loop(Looper.java:148)
02-03 14:04:14.266 884 884 E AndroidRuntime: at com.android.server.SystemServer.run(SystemServer.java:283)
02-03 14:04:14.266 884 884 E AndroidRuntime: at com.android.server.SystemServer.main(SystemServer.java:168)
02-03 14:04:14.266 884 884 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method)
02-03 14:04:14.266 884 884 E AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
02-03 14:04:14.266 884 884 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
02-03 14:04:14.348 884 884 I Process : Sending signal. PID: 884 SIG: 9
Мой код находится в функции executeTraversals и просто отправляет сообщения между потоками. Вот мой код:
Классы:
public class Viewhandler extends Handler{
Viewhandler(){}
@Override
public void handleMessage(Message msg) {
Log.v("Viewhandler","msg-" + msg.arg1);
}
}
public class Vthread extends Thread{
Viewhandler mViewhandler;
Handler mhandler;
Vthread(Viewhandler handler){
mViewhandler = handler;
}
@Override
public void run(){
Looper.prepare();
mhandler = new Handler(){
@Override
public void handleMessage(Message msg) {
Log.v("Vthread","msg-" + msg.arg1);
Message mes = Message.obtain();
mes.arg1 = 2000;
mViewhandler.sendMessage(mes);
}
};
Looper.loop();
}
}
Код в функции executeTraversals:
if(mViewhandler == null){
Log.v(TAG, "viewhandler");
mViewhandler = new Viewhandler();
}
if(mVthread == null){
Log.v(TAG, "vthread");
mVthread = new Vthread(mViewhandler);
mVthread.start();
}
Log.v(TAG, "message");
Message msg = Message.obtain();
msg.arg1 = 1000;
mVthread.mhandler.sendMessage(msg);
Я не могу создавать темы в этом файле?
Еще вопросы: есть ли у каждого приложения своя копия фреймворков? Как это работает для платформ Android?
Спасибо
1 ответ
Решение
mVthread.mhandler
является null
,
Вы не можете полагаться на то, что происходит внутри run()
после того как ты позвонил start()
без правильной синхронизации.
Скорее всего, поток еще не был запущен, когда вы читаете mhandler
,
Переехать mhandler = new Handler()...
к Vthread
конструктор.