使用模拟器测试AdMob时出现“E / Ads:等待未来出错”错误

时间:2018-05-15 08:49:59

标签: android admob

我按照所有必需的程序在模拟器上测试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);
  }
}

我尝试在依赖项实施中将播放服务广告降低到版本12,确保将权限添加到Android工作室上的清单,更新的Google服务播放和Android图像以进行最新更新;还确保我的帐户在AdMob上有效且adUnit处于有效状态,但仍然存在同样的问题 在此先感谢您的帮助

1 个答案:

答案 0 :(得分:2)

这是谷歌所说的 我有这个问题回来了!我等了解决了!并且它也不会显示实时广告,它只会给你一个虚拟添加的admob,只是为了告诉它它正在工作!

用简单的话说!

“可能是您最近刚创建了一个新的广告单元ID并要求投放实时广告。如果是这种情况,广告可能需要几个小时才能开始投放。如果您收到测试广告,那么您的实施没问题。只需等待几个小时,看看您是否能够接收实时广告。如果没有,可以将您的广告单元ID发送给我们以供我们查看。“

所以基本上你要等几个小时

检查 LINK 以查找我从GOOGLE谈过的资源

如果问题仍然存在

然后一个一个地检查应用程序

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

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

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

    AdRequest adRequest = new AdRequest.Builder()。addTestDevice(您的设备ID)  //在模拟器上进行测试时 .addTestDevice(AdRequest.DEVICE_ID_EMULATOR).build();

  4. 4:检查你的应用程序的清单中是否有关于google play版本的metaTag

    enter image description here

    检查 THREAD 以获取更多提示