AdMob: "activity has leaked ServiceConnection" 和 "AdvertisingIdClient unbindService failed." AdMob:活动泄漏了ServiceConnection并且AdvertisingIdClient取消绑定服务失败。

16

我在我的应用中使用AdMob。我遵循了实现指南,横幅正确地显示和加载广告。我的MainActivity负责创建引用、构建AdRequest并显示横幅,以及暂停、恢复和销毁AdView。每次AdRequest被加载时,在Activity的onStop()被调用时,将创建以下异常:

6706-6706/com.rocca.controlloSpese E/ActivityThread﹕ Activity com.rocca.controlloSpese.MainActivity has leaked ServiceConnection com.google.android.gms.common.b@52b1cc3c that was originally bound here
android.app.ServiceConnectionLeaked: Activity com.rocca.controlloSpese.MainActivity has leaked ServiceConnection com.google.android.gms.common.b@52b1cc3c that was originally bound here
        at android.app.LoadedApk$ServiceDispatcher.<init>(LoadedApk.java:970)
        at android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:864)
        at android.app.ContextImpl.bindServiceCommon(ContextImpl.java:1577)
        at android.app.ContextImpl.bindService(ContextImpl.java:1560)
        at android.content.ContextWrapper.bindService(ContextWrapper.java:517)
        at com.google.android.gms.ads.identifier.a.b(SourceFile:330)
        at com.google.android.gms.ads.identifier.a.a(SourceFile:187)
        at com.google.android.gms.ads.identifier.a.b(SourceFile:239)
        at com.google.android.a.t.f(SourceFile:132)
        at com.google.android.a.t.b(SourceFile:182)
        at com.google.android.a.q.a(SourceFile:258)
        at com.google.android.a.q.a(SourceFile:195)
        at com.google.android.gms.ads.internal.m.a(SourceFile:107)
        at com.google.android.gms.ads.internal.request.c.a(SourceFile:99)
        at com.google.android.gms.ads.internal.util.b.run(SourceFile:17)
        at com.google.android.gms.ads.internal.util.d.call(SourceFile:29)
        at com.google.android.gms.ads.internal.util.e.call(SourceFile:49)
        at java.util.concurrent.FutureTask.run(FutureTask.java:237)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
        at java.lang.Thread.run(Thread.java:841)

接着是这些信息:

6706-6781/com.rocca.controlloSpese I/AdvertisingIdClient﹕ AdvertisingIdClient unbindService failed.
java.lang.IllegalArgumentException: Service not registered: com.google.android.gms.common.b@52b1cc3c
        at android.app.LoadedApk.forgetServiceDispatcher(LoadedApk.java:922)
        at android.app.ContextImpl.unbindService(ContextImpl.java:1611)
        at android.content.ContextWrapper.unbindService(ContextWrapper.java:529)
        at com.google.android.gms.ads.identifier.a.c(SourceFile:275)
        at com.google.android.gms.ads.identifier.b.c(SourceFile:100)
        at com.google.android.gms.ads.identifier.b.run(SourceFile:110)

如果AdRequest没有被构建和加载,就不会发生这种情况。我在onCreate()中设置了我的IABHelper,如果用户没有购买我的“去广告”sku,那么就会显示广告。这是我用来加载广告的代码:

private void showAds() {
    int adresult = GooglePlayServicesUtil.isGooglePlayServicesAvailable(MainActivity.this);
    if (adresult == ConnectionResult.SUCCESS) {
        //if possible, show ads
        AdRequest adRequest = new AdRequest.Builder()
                .addTestDevice(AdRequest.DEVICE_ID_EMULATOR) 
                .addTestDevice("C144E9DA02EA7B26F74ED2C231F31D38") 
                .addTestDevice("93BABD84466B8C1EF529D2FB39D1ACE8") 
                .addTestDevice("BEAA738068664AE9BBF673E37A782E03") 
                .addTestDevice("E51508081F77DF84C129EE471DE67141") 
                .build();
        adView.setVisibility(View.VISIBLE);
        adView.loadAd(adRequest);
    } else {
        //if there's a problem, show error and close app
        GooglePlayServicesUtil.getErrorDialog(adresult, MainActivity.this, 0, new DialogInterface.OnCancelListener() {
            @Override
            public void onCancel(DialogInterface dialogInterface) {
                finish();
            }
        }).show();
    }
}

在相应的活动方法中调用adView的pause()resume()destroy()。实际上,这不会影响应用程序的表现,但我宁愿避免内存泄漏。如何避免该异常?

编辑:Manifest.xml文件

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.rocca.controlloSpese" >

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="com.android.vending.BILLING" />
<uses-permission android:name="com.rocca.controlloSpese.BROADCAST_PERMISSION" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name=".MainActivity"
        android:finishOnCloseSystemDialogs="true"
        android:label="@string/app_name"
        android:launchMode="singleTop" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <meta-data
        android:name="com.google.android.gms.version"
        android:value="@integer/google_play_services_version" />
    <activity
        android:name="com.google.android.gms.ads.AdActivity"
        android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|uiMode|screenSize|smallestScreenSize" />        
</application>

你能把你的清单文件放在这里吗? - Akash Moradiya
您IP地址为143.198.54.68,由于运营成本限制,当前对于免费用户的使用频率限制为每个IP每72小时10次对话,如需解除限制,请点击左下角设置图标按钮(手机用户先点击左上角菜单按钮)。 - devrocca
你在onStop()方法中做了什么特别的事情吗? - Michael
在onStop()中,只有一行与admob无关的代码,甚至不值得更新问题。 - devrocca
似乎他们正在解决这个问题。 - D-rk
2个回答

8
我发现在使用AdMob网站上的快速入门示例项目(链接在此)时,出现了完全相同的情况。我在Nexus 5上运行Lollipop系统时也遇到了这个问题。
因此,我认为这是AdMob的一个bug。
有没有办法得到AdMob服务的引用并手动解除服务绑定,以查看是否可以停止错误?

一样的情况。我以为这与mopub适配器有关,但看起来不是这样。你找到解决方案了吗? - Viral Patel
我也遇到了同样的问题,我的应用程序使用了Google Play服务AdMob。 - Ersen Osman
同样的问题。你有什么解决方案吗? - Rahul Mandaliya

4
以下代码解决了我的问题;
@Override
    protected void onDestroy() {
        // TODO Auto-generated method stub
        mAdView.destroy();
        super.onDestroy();
    }

@Override
protected void onResume() {
    // TODO Auto-generated method stub
    super.onResume();
    mAdView.resume();

}


@Override
protected void onPause() {
    // TODO Auto-generated method stub
    super.onPause();

    mAdView.pause();
}

正如我在原帖中所述,我正在进行这些调用,但是异常仍然发生。也许你想分享一下你的onCreate()方法? - devrocca
抱歉我的帖子。我已经尝试了一两次,没有看到任何错误。但之后我发现了错误,就像你所看到的那样,所以我的方法不起作用了。我仍在寻找解决方法,请告诉我如果你找到了一些解决方案。谢谢 :) - Onur Öztürk
问题已经解决。 - Lizozom

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