Я получаю большое количество сообщений об ошибках от пользователей, о которых сообщалось в диалоговых окнах принудительного закрытия, в которых указано что-то вроде следующего:
java.lang.ExceptionInInitializerError
at com.MyRequest.execute(MyRequest.java:59)
at org.nsdev.MySyncAdapter.onPerformSync(MySyncAdapter.java:90)
at android.content.AbstractThreadedSyncAdapter$SyncThread.run(AbstractThreadedSyncAdapter.java:164)
Caused by: java.lang.RuntimeException:
Can't create handler inside thread that has not called Looper.prepare()
at android.os.Handler.<init>(Handler.java:121)
at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421)
at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421)
at android.os.AsyncTask.<clinit>(AsyncTask.java:152)
Теперь я пытаюсь выяснить, как мне лучше всегорешить эту проблему.Внутри моей реализации onPerformSync я создаю несколько AsyncTasks и выполняю их.Я подозреваю, что моя проблема в том, что я не жду завершения этих задач, прежде чем вернуться из onPerformSync.Я попытался сделать следующее:
Looper.prepare();
// Execute async tasks
Looper.loop();
А затем я установил счетчик, и когда этот счетчик уменьшится до нуля, вызову Looper.myLooper (). Quit () внутри функции обратного вызова из асинхронных задач.
Но из-за этого происходит сбой в работе моего приложения со следующей ошибкой времени выполнения:
java.lang.RuntimeException: Main thread not allowed to quit
at android.os.MessageQueue.enqueueMessage(MessageQueue.java:175)
at android.os.Looper.quit(Looper.java:173)
at org.nsdev.MySyncAdapter$1.requestFinished(MySyncAdapter.java:89)
at com.MyAsyncTask.onPostExecute(MyAsyncTask.java:84)
at android.os.AsyncTask.finish(AsyncTask.java:417)
at android.os.AsyncTask.access$300(AsyncTask.java:127)
at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4627)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
Есть идеи, как правильно выполнить синхронизацию?