このようにアプリで ThreadHandler を使用していますが、
public class MessageThread extends HandlerThread {
Handler mHandler;
public MessageThread() {
super("Message Thread");
}
public void queueProcessMessage(msgObject mObj) {
mHandler.obtainMessage(PROCESS_MESSAGE, mObj).sendToTarget();
}
@Override
protected void onLooperPrepared() {
Commons.logIt("OnLoopPrep");
mHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case PROCESS_MESSAGE:
process_message((msgObject) msg.obj);
break;
default:
break;
}
}
};
}
process_message(msgObject obj) {
//Do stuff
}
}
そして、私は onCreate() でそれを初期化します
public void onCreate(Bundle savedInstanceState) {
MessageThread mThread = new MessageThread();
mThread.start();
mThread.getLooper();
if (mThread != null)
mThread.queueProcessMessage(Object);// this is the line the compiler is pointing at.
}
問題は、結果を待っている別のアクティビティを開始する必要がある場所に何かを追加する必要があったため、結果のアクティビティを開始するときに onActivityResult が onCreate の前に呼び出されるため、以下に示すように初期化/使用する必要があったことです。 、今回はエラーが発生しています
java.lang.NullPointerException: Attempt to invoke virtual method 'android.os.Message android.os.Handler.obtainMessage(int, java.lang.Object)' on a null object reference
.
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == IMAGE_ACTIVITY_REQUEST_CODE) {
if (resultCode == Activity.RESULT_OK) {
MessageThread mThread = new MessageThread();
mThread.start();
mThread.getLooper();
mThread.queueProcessMessage(new msgObject("stuff"));
}
}
}
スレッドが初期化されていないようですが、ここで何が欠けていますか?
編集1、
ここで問題について話し合った後、ハンドラーが初期化されるのに少し時間がかかるようです。私はこれを行いました。醜いですが、機能しています。
public void queueProcessMessage(msgObject mObj) {
while (mHandler == null)
Log.i(TAG, "Not init yet"); //It keeps on looping here
mHandler.obtainMessage(PROCESS_MESSAGE, mObj).sendToTarget();
}