我只是将我的第一个应用程序放在网上,但它一直在崩溃,我不知道为什么:它在模拟器上工作正常。
这是一款使用自定义SurfaceView
和位图的小游戏。
我报告了崩溃,我得到了一个我不明白的logcat。
java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child's parent first.
at android.view.ViewGroup.addViewInner(ViewGroup.java:3566)
at android.view.ViewGroup.addView(ViewGroup.java:3437)
at android.view.ViewGroup.addView(ViewGroup.java:3382)
at android.view.ViewGroup.addView(ViewGroup.java:3358)
at com.jumping_jack.jjack.MainActivity$1.onAdLoaded(MainActivity.java:68)
at com.google.android.gms.internal.at.onAdLoaded(Unknown Source)
at com.google.android.gms.internal.bc$a.onTransact(Unknown Source)
at android.os.Binder.transact(Binder.java:310)
at com.google.android.gms.ads.internal.client.h.c(SourceFile:152)
at com.google.android.gms.ads.internal.b.v(SourceFile:1351)
at com.google.android.gms.ads.internal.b.a(SourceFile:777)
at com.google.android.gms.ads.internal.request.m.run(SourceFile:173)
at android.os.Handler.handleCallback(Handler.java:725)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5283)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
at dalv
java.lang.NullPointerException
at com.jumping_jack.jjack.GameLoop.draw(GameLoop.java:220)
at com.jumping_jack.jjack.GameLoop.run(GameLoop.java:161)
at java.lang.Thread.run(Thread.java:856)
ik.system.NativeStart.main(Native Method)
我怀疑这是错误的代码
adView.setAdListener(new AdListener() {
public void onAdLoaded(){
adLoaded = true;
mainLayout.removeView(splashScreen);
set1.recycle();
bm.recycle();
System.gc();
mainLayout.addView(sView);
adView.bringToFront();
}
}
我的猜测是,当重新加载广告时,它再次调用此功能,但我不确定。
另外,我检查了我的缓存5.66 mb:我不知道这是否也是一个问题。
如果您了解日志,请帮助我。
就像我说的,在模拟器上,它工作正常,所以我不想更新它。谢谢!
答案 0 :(得分:0)
您的堆栈跟踪已经为您提供了答案:
java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child's parent first.