Caused by: android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.B

本文分析了一个关于Android应用程序启动时发生的致命异常,详细解释了BadTokenException错误产生的原因,并提供了解决此类问题的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个bug日志

 FATAL EXCEPTION: main
03-25 14:24:07.724: E/AndroidRuntime(4135): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.syyx.jingubang.ky/com.anguotech.android.activity.InitAndUpdateActivity}: android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@427f01a0 is not valid; is your activity running?
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2072)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2097)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.ActivityThread.access$600(ActivityThread.java:137)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1205)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.os.Handler.dispatchMessage(Handler.java:99)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.os.Looper.loop(Looper.java:137)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.ActivityThread.main(ActivityThread.java:4808)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at java.lang.reflect.Method.invokeNative(Native Method)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at java.lang.reflect.Method.invoke(Method.java:511)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at dalvik.system.NativeStart.main(Native Method)
03-25 14:24:07.724: E/AndroidRuntime(4135): Caused by: android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@427f01a0 is not valid; is your activity running?
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.view.ViewRootImpl.setView(ViewRootImpl.java:591)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:326)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:224)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:149)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.view.Window$LocalWindowManager.addView(Window.java:547)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.Dialog.show(Dialog.java:277)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at com.anguotech.android.util.MyProgressBar.show(MyProgressBar.java:47)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at com.anguotech.android.util.MyProgressBar.show(MyProgressBar.java:54)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at com.anguotech.android.activity.InitAndUpdateActivity.upLoadBaseData(InitAndUpdateActivity.java:97)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at com.anguotech.android.activity.InitAndUpdateActivity.onCreate(InitAndUpdateActivity.java:45)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.Activity.performCreate(Activity.java:5010)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
03-25 14:24:07.724: E/AndroidRuntime(4135):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2036)
03-25 14:24:07.724: E/AndroidRuntime(4135):     ... 11 more

出现这个问题的原因,是因为在代码中的dialog和progressBar没有及时销毁的缘故。这两个都是依赖于Activity界面的,当Activtiy被销毁了,它们也必须调用cancle放来来销毁。

解决办法: 在Activity生命周期的onDestroy方法中销毁。

@Override
    protected void onDestroy() {
        super.onDestroy();
        // 当Activity销毁时,必须把使用的dialog或者progressBar也销毁
        if (progressBar != null) {
            progressBar.cancel();
            progressBar = null;
        }
        if(dialog!=null){
             dialog.canel();
             dialog = null;
        }


    }
``` FATAL EXCEPTION: main Process: com.oem.qisda, PID: 6430 java.lang.RuntimeException: Unable to create service com.oem.qisda.CpuInfoService: android.view.WindowManager$BadTokenException: Unable to add window android.view.ViewRootImpl$W@9519714 -- permission denied for window type 2038 at android.app.ActivityThread.handleCreateService(ActivityThread.java:4568) at android.app.ActivityThread.access$1700(ActivityThread.java:257) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2111) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loopOnce(Looper.java:201) at android.os.Looper.loop(Looper.java:288) at android.app.ActivityThread.main(ActivityThread.java:7911) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:681) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1009) Caused by: android.view.WindowManager$BadTokenException: Unable to add window android.view.ViewRootImpl$W@9519714 -- permission denied for window type 2038 at android.view.ViewRootImpl.setView(ViewRootImpl.java:1215) at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:400) at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:139) at com.oem.qisda.CpuInfoService.onCreate(CpuInfoService.java:105) at android.app.ActivityThread.handleCreateService(ActivityThread.java:4555) at android.app.ActivityThread.access$1700(ActivityThread.java:257)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2111)  at android.os.Handler.dispatchMessage(Handler.java:106)  at android.os.Looper.loopOnce(Looper.java:201)  at android.os.Looper.loop(Looper.java:288)  at android.app.ActivityThread.main(ActivityThread.java:7911)  at java.lang.reflect.Method.invoke(Native Method)  at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:681)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1009)```怎么解决
03-08
07-20 19:57:40.672 5131 5131 D AndroidRuntime: Shutting down VM --------- beginning of crash 07-20 19:57:40.673 5131 5131 E AndroidRuntime: FATAL EXCEPTION: main 07-20 19:57:40.673 5131 5131 E AndroidRuntime: Process: com.adayo.aaop_deviceservice, PID: 5131 07-20 19:57:40.673 5131 5131 E AndroidRuntime: java.lang.RuntimeException: Unable to create service com.adayo.aaop_deviceservice.service.BurialPointService: android.view.WindowManager$InvalidDisplayException: Unable to add window android.view.ViewRootImpl$W@e6477e5 -- the specified display can not be found 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.app.ActivityThread.handleCreateService(ActivityThread.java:4221) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.app.ActivityThread.access$1600(ActivityThread.java:238) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1955) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:106) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.os.Looper.loop(Looper.java:223) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:7731) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: Caused by: android.view.WindowManager$InvalidDisplayException: Unable to add window android.view.ViewRootImpl$W@e6477e5 -- the specified display can not be found 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.view.ViewRootImpl.setView(ViewRootImpl.java:1099) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:409) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:109) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.app.Dialog.show(Dialog.java:342) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.app.Presentation.show(Presentation.java:257) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at com.adayo.aaop_deviceservice.service.BurialPointService.x(Unknown Source:77) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at com.adayo.aaop_deviceservice.service.BurialPointService.A(Unknown Source:50) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at com.adayo.aaop_deviceservice.service.BurialPointService.onCreate(Unknown Source:10) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: at android.app.ActivityThread.handleCreateService(ActivityThread.java:4209) 07-20 19:57:40.673 5131 5131 E AndroidRuntime: ... 8 more 07-20 19:57:40.676 5131 5131 I Process : Sending signal. PID: 5131 SIG: 9 private void createBackgroundToQnx() { DisplayManager displayManager = (DisplayManager)this.getSystemService(Context.DISPLAY_SERVICE); Display[] displays = displayManager.getDisplays(); Log.i(TAG, "createBackgroundToQnx displays = " + Arrays.toString(displays)); for (Display display : displayManager.getDisplays()) { if (display.getDisplayId() == 1) { Presentation presentation = new Presentation(this, displayManager.getDisplay(1)); View view = new View(this); view.setBackgroundColor(Color.BLACK); presentation.setContentView(view); presentation.show(); } } }
最新发布
08-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值