首页 > 解决方案 > 使用模拟器测试 AdMob 时出现“E/Ads:错误等待未来”错误

问题描述

我按照所有必需的程序在模拟器上测试 AdMob,但在日志中出现以下错误:

E/Ads: Error waiting for future.
   java.util.concurrent.ExecutionException: java.util.concurrent.TimeoutException
       at com.google.android.gms.internal.ads.zzaoj.get(Unknown Source:35)
       at com.google.android.gms.internal.ads.zzano.zza(Unknown Source:19)
       at com.google.android.gms.internal.ads.zzafn.zza(Unknown Source:621)
       at com.google.android.gms.internal.ads.zzafn.zzb(Unknown Source:6)
       at com.google.android.gms.internal.ads.zzafp.run(Unknown Source:4)
       at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:457)
       at java.util.concurrent.FutureTask.run(FutureTask.java:266)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
       at java.lang.Thread.run(Thread.java:764)
    Caused by: java.util.concurrent.TimeoutException
       at com.google.android.gms.internal.ads.zzans.run(Unknown Source:4)
       at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:457)
       at java.util.concurrent.FutureTask.run(FutureTask.java:266)
       at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:301)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162) 
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636) 
       at java.lang.Thread.run(Thread.java:764) 
W/Ads: There was a problem getting an ad response. ErrorCode: 0
W/Ads: Failed to load ad: 0

XML 代码如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_height="match_parent"
android:layout_width="match_parent"
tools:context=".MainActivity">

<TextView android:text="Hi"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content" />

<com.google.android.gms.ads.AdView
  xmlns:ads="http://schemas.android.com/apk/res-auto"
  android:id="@+id/adView"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_centerHorizontal="true"
  android:layout_alignParentBottom="true"
  ads:adSize="BANNER"
  ads:adUnitId="@string/banner_id">
</com.google.android.gms.ads.AdView>

</RelativeLayout>

活动代码是:

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import com.google.android.gms.ads.AdRequest;
import com.google.android.gms.ads.AdView;
import com.google.android.gms.ads.MobileAds;

public class MainActivity extends AppCompatActivity {

  private AdView mAdView;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      MobileAds.initialize(this,
              getResources().getString(R.string.app_ad_id));
      mAdView = findViewById(R.id.adView);
      AdRequest adRequest = new AdRequest.Builder()
        .addTestDevice(AdRequest.DEVICE_ID_EMULATOR).build();
    mAdView.loadAd(adRequest);
  }
}

我尝试在依赖项实现中将 play-services-ads 降低到版本 12,确保将权限添加到清单中,将 Android Studio 上的 google service play 和 android 图像更新为最新更新;还确保我的帐户在 AdMob 上处于活动状态并且 adUnits 处于活动状态,但仍然存在同样的问题提前感谢您的帮助

标签: androidadmob

解决方案


这就是谷歌所说的我以前遇到过这个问题!我等着解决了!而且它也不会显示实时广告,它只会给你一个admob的虚拟添加,只是为了告诉你它正在工作!

简单来说!

“可能是您最近才创建了一个新的广告单元 ID 并请求实时广告。如果是这种情况,可能需要几个小时才能开始投放广告。如果您正在接收测试广告,那么您的实施就很好. 等几个小时,看看你是否能收到实时广告。如果没有,可以把你的广告单元 ID 发给我们,让我们调查。

所以基本上你必须等待几个小时

查看我从 GOOGLE 谈到的资源的链接

如果问题仍然存在

然后一一做这些并检查应用程序

  1. 尝试检查您的 UNIT ID 可能是错误的

  2. 尝试检查您提供的包名称在 admob 端是否相同

  3. 通过告诉 admob 使用这个在模拟器上进行测试,尝试通过模拟器进行测试

    AdRequest adRequest = new AdRequest.Builder().addTestDevice(your device id) //当你在模拟器上测试时 .addTestDevice(AdRequest.DEVICE_ID_EMULATOR).build();

4:检查你的应用程序清单是否有你告诉谷歌播放版本的元标签

在此处输入图像描述

检查此线程以获取更多提示


推荐阅读