web-dev-qa-db-ja.com

サービスにバインドできませんでした

アプリの起動で、Play Storeで新しいバージョンが利用可能かどうかを確認する必要があります。私はスプラッシュスクリーンのコードの下に実装されました。

private void checkNewVersionAvailability() {
    appUpdateManager = AppUpdateManagerFactory.create(getApplicationContext());
    appUpdateInfo = appUpdateManager.getAppUpdateInfo();

    appUpdateInfo.addOnCompleteListener(new OnCompleteListener<AppUpdateInfo>() {
        @Override
        public void onComplete(Task<AppUpdateInfo> task) {
            if (task.isComplete()) {
                if (task.getResult().updateAvailability() == UpdateAvailability.UPDATE_AVAILABLE) {
                    checkVersion(task.getResult());
                } else if (task.getResult().updateAvailability() == UpdateAvailability.UPDATE_NOT_AVAILABLE) {
                    if (StringUtils.isNullOrEmpty(ChevronApplication.deviceId)) {
                        new Handler().postDelayed(new Runnable() {
                            @Override
                            public void run() {
                                RegsiterDeviceHandler handler = new RegsiterDeviceHandler(SplashScreen.this);
                                handler.registerDevice(false);
                                handler.showNextScreen();
                            }
                        }, SLEEP_TIME);
                    } else {
                        new Handler().postDelayed(new Runnable() {
                            @Override
                            public void run() {
                                new RegsiterDeviceHandler(SplashScreen.this).showNextScreen();
                            }
                        }, SLEEP_TIME);
                    }
                }
            }
        }
    });
 _

デバイス上でのテスト中に、問題が発生しませんでした。これらのクラッシュログは、PlayStoreの起動前のレポートから見つかりました。 enter image description here

> FATAL EXCEPTION: main
Process: com.mac.app, PID: 19641
com.google.Android.play.core.tasks.RuntimeExecutionException: com.google.Android.play.core.internal.aa: Failed to bind to the service.
    at com.google.Android.play.core.tasks.k.getResult(Unknown Source)
    at com.chevronrenaissance.app.activity.SplashScreen$2.onComplete(SplashScreen.Java:113)
    at com.google.Android.play.core.tasks.a.run(Unknown Source)
    at Android.os.Handler.handleCallback(Handler.Java:739)
    at Android.os.Handler.dispatchMessage(Handler.Java:95)
    at Android.os.Looper.loop(Looper.Java:135)
    at Android.app.ActivityThread.main(ActivityThread.Java:5538)
    at Java.lang.reflect.Method.invoke(Native Method)
    at Java.lang.reflect.Method.invoke(Method.Java:372)
    at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:960)
    at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:755)
Caused by: com.google.Android.play.core.internal.aa: Failed to bind to the service.
    at com.google.Android.play.core.internal.q.b(Unknown Source)
    at com.google.Android.play.core.internal.q.a(Unknown Source)
    at com.google.Android.play.core.internal.s.a(Unknown Source)
    at com.google.Android.play.core.internal.r.run(Unknown Source)
    at Android.os.Handler.handleCallback(Handler.Java:739)
    at Android.os.Handler.dispatchMessage(Handler.Java:95)
    at Android.os.Looper.loop(Looper.Java:135)
    at Android.os.HandlerThread.run(HandlerThread.Java:61)
 _
9
Rohan Patel

task.isSuccessful()を確認できます。この場合、タスクが成功しなかった場合は、例外使用方法task.getException()を取得できます。

0
Dmitriy