2016-10-24 58 views
23

我在我的应用程序上实施了GCM通知。我现在正试图在用户注销时取消注册应用程序。我正在使用下面的代码。当这段代码执行时,它会导致应用程序具有以下logcat的崩溃:GCM取消注册导致应用程序崩溃

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创造了这个问题 –

回答

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") 
+0

它帮助我。非常感谢:-) –

+0

不错的抓+1, –

+1

我试着更新但不解决任何问题。仍然相同的错误 –

1

不知道这会解决您的问题,但它总是一个好主意将应用程序Context传递给第三方框架,而不是Activity实例,因为后者可能导致内存泄漏。试试这个来代替:

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

我累了,但没有运气:-( –

4

更新的谷歌更新了Android支持库25.0.0 后玩到最新版本(9.8.0)服务今早我同样的问题,这个工作对我来说:)

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