GCM注销导致应用程序崩溃。

24

我在我的应用上实现了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();
}

1
对我来说,编译facebooksdk时出现了这个问题。 - Vidya Sagar
4个回答

43

更新支持库至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")

它帮助了我。非常感谢 :-) - Zeeshan Ali
1
我尝试更新,但没有解决任何问题。错误仍然存在。 - Francesco Frascà
我尝试了这种方法,但没有运气。您能否在这里帮助我?这是我的问题:https://dev59.com/Vek6XIcBkEYKwwoYAfGc。 - Arpit Patel
1
你使用的google-services插件版本是多少?我在尝试更新9.6.1时遇到了版本冲突错误。 - pasanbuddhika
@pasanbuddhika 我使用的是3.0.0版本。 - luizMello

4

在更新 Android support library 到 25.0.0 版本后,将 Google Play Services 更新到最新版本(9.8.0)。我今天早上遇到了同样的问题,这个方法对我有用 :)


2

我不确定这是否能解决你的问题,但将应用程序的Context传递给第三方框架通常比传递Activity实例更好,因为后者可能会导致内存泄漏。请尝试使用以下代码:

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

1
我很努力了,但没有运气 :-( - Zeeshan Ali

0

按照给定的方式使用依赖项

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;
    }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接