web-dev-qa-db-ja.com

GCM登録解除によりアプリケーションがクラッシュする

アプリにGCM通知を実装しました。ユーザーがログアウトしたときにアプリの登録を解除しようとしています。次のコードを使用しています。このコードを実行すると、次のlogcatでアプリケーションがクラッシュします。

Java.lang.IllegalAccessError: Method 'void Android.support.v4.content.ContextCompat.<init>()' is inaccessible to class 'com.google.Android.gms.iid.zzd' (declaration of 'com.google.Android.gms.iid.zzd' appears in /data/app/com.example.packagename-1/base.apk)
    at com.google.Android.gms.iid.zzd.zzeb(Unknown Source)
    at com.google.Android.gms.iid.zzd.<init>(Unknown Source)
    at com.google.Android.gms.iid.zzd.<init>(Unknown Source)
    at com.google.Android.gms.iid.InstanceID.zza(Unknown Source)
    at com.google.Android.gms.iid.InstanceID.getInstance(Unknown Source)
    at com.zaryans.updatedepoultry.WelcomeActivity$11.onItemClick(WelcomeActivity.Java:469)
    at Android.widget.AdapterView.performItemClick(AdapterView.Java:310)
    at Android.widget.AbsListView.performItemClick(AbsListView.Java:1145)
    at Android.widget.AbsListView$PerformClick.run(AbsListView.Java:3066)
    at Android.widget.AbsListView$3.run(AbsListView.Java:3903)
    at Android.os.Handler.handleCallback(Handler.Java:739)
    at Android.os.Handler.dispatchMessage(Handler.Java:95)
    at Android.os.Looper.loop(Looper.Java:148)
    at Android.app.ActivityThread.main(ActivityThread.Java:5417)
    at Java.lang.reflect.Method.invoke(Native Method)
    at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:726)
    at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:616)

コードは次のとおりです。

InstanceID instanceID = InstanceID.getInstance(WelcomeActivity.this);
try {
   instanceID.deleteInstanceID();
   Utility.logCatMsg("Logged Out Success!!!");
} catch (IOException e) {
   Utility.logCatMsg("Exception while logging out: "+e.getMessage());
   e.printStackTrace();
}
24
Zeeshan Ali

サポートライブラリを25.0.0に更新した後、同じ問題が発生しました。私にとっては、アプリのgradleファイルで以下のライブラリを更新した後、問題はなくなりました。

compile("com.google.Android.gms:play-services-location:9.6.1")
compile("com.google.Android.gms:play-services-maps:9.6.1")
compile("com.google.Android.gms:play-services-gcm:9.6.1")
43
luizMello

Androidサポートライブラリを25.0.0に更新した後、Google Playサービスを最新バージョン(9.8.0)に更新します。今朝、同じ問題が発生しました。

4
AndroidGeek

これで問題が解決するかどうかはわかりませんが、アプリケーションContextをメモリリークにつながる可能性があるため、Activityインスタンスではなく、サードパーティのフレームワークにアプリケーションを渡すことをお勧めします。代わりにこれを試してください:

InstanceID instanceID = InstanceID.getInstance(getApplicationContext());
2
Egor

指定された方法で依存関係を使用する

compile ("com.google.Android.gms:play-services-base:10.0.1") {
        force = true;
    }
    compile ("com.google.Android.gms:play-services-maps:10.0.1") {
        force = true;
    }
    compile ("com.google.Android.gms:play-services-gcm:10.0.1") {
        force = true;
    }
    compile ('com.google.firebase:firebase-core:10.0.1') {
        force = true;
    }
    compile ('com.google.firebase:firebase-messaging:10.0.1') {
        force = true;
    }
0
Shubham Goel