Создание потока в 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 конструктор.

Другие вопросы по тегам