2016-10-24 59 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; 
    }