ActivityGroup window bad token问题深入分析

如有转载,请声明出处: 时之沙: http://blog.csdn.net/t12x3456


ActivityGroup window bad token问题深入分析

近期帮别人调试一个webview的页面,非常奇怪的遇到了下面问题:

H5页面中会检測地址中传递的參数,若检測到特定參数异常,则会弹出Dialog进行提示

Dialog:android.view.WindowManager$BadTokenException:

可是在单独的測试project中并没有发生异常,这时我注意到日志中包括localactivitymanager的内容。之后发现果然是仅仅有在TabHost中才会发生这样的情况.

相似的情况,假设我们在ActivityGroup或者TabActivity中的子Activity创建Dialog若使用下面的代码

progressDialog = new ProgressDialog(XXX.this)

创建就会出现例如以下Exception:

05-24 12:34:42.236: ERROR/AndroidRuntime(6362): android.view.WindowManager$BadTokenException: Unable to add window -- token [email protected] is not valid; is your activity running?

实际上出现这样的问题的主要原因是显示UI界面时,context选择错误。

由于new对话框的时候,參数content 指定成了this,即指向当前子Activity的content。

但子Activity是动态创建的。不能保证一直存在。

其父Activity的content是稳定存在的,所以有下面的解决的方法

若ActivityGroup中嵌套ActivityGroup,嵌套多少就该使用多少个getParent()。

为什么要使用getParent我们能够从ActivityGroup的内部机制来理解:
TabActivity的父类是ActivityGroup,而ActivityGroup的父类是Activity。因此从Ams的角度来看。ActivityGroup与普通的Activity没有什么差别,其生命周期包括标准的start,stop,resume,destroy等。并且系统中仅仅同意同一时候同意一个ActivityGroup.但ActivityGroup内部有一个重要成员变量。其类型为LocalActivityManager,该类的最大特点在于它能够訪问应用进程的主类,即ActivityThread类。

Ams要启动某个Activity或者赞同某个Activity都是通过ActivityThread类执行的。而LocalActivityManager类就意味着能够通过它来装载不同的Activity,并控制Activity的不同的状态。注意,这里是装载,而不是启动,这点非常重要。所谓的启动,通常是指会创建一个进程(假设所在的应用常常还不存在)执行该Activity,而装载仅仅是指把该Activity作为一个普通类进行载入,并创建一个该类的对象而已,而该类的不论什么函数都没有被执行。

装载Activity对象的过程对AmS来讲是全然不可见的,那些嵌入的Activity仅仅贡献了自己所包括的Window窗体而已。而子Activity的不同状态是通过moveToState来处理的。

所以子Activity不是像普通的Activity一样。它仅仅是提供Window而已。所以在创建Dialog时就应该使用getParent获取ActivityGroup真正的Activity,才干够加Dialog增加Activity中。

假设遇到相似的 window bak token的异常,我们也能够从这个方面着手去分析解决.

时间: 2024-10-01 03:07:33

ActivityGroup window bad token问题深入分析的相关文章

使用json web token

由来 做了这么长时间的web开发,从JAVA EE中的jsf,spring,hibernate框架,到spring web MVC,到用php框架thinkPHP,到现在的nodejs,我自己的看法是越来越喜欢干净整洁的web层,之前用jsf开发做view层的时候,用的primefaces做的界面显示,虽然primefaces的确提供了很大的便利,可以让开发人员专注于业务逻辑开发,这样其实就省去了前端开发的工作.而后来发现有些客户需要的展现形式很难实现,或者通过拼凑的方法实现的结果效率不高.使用

[Android]浮层视频效果,在另外一个Window使用SurfaceView无法正常显示的问题排查与解决

最近在忙碌视频的事情,而视频的绘制需要使用到SurfaceView.为了完成浮层效果,我们很自然的想到使用多Window的方式.但是问题就来了,当你将你的SurfaceView放置在另外一个window中的时候,一切都变得不正常,为了验证这个东西,我写了一个小的demo: 代码非常简单,按下中间那个按钮,弹出一个Window,这个Window里面存放一个简单的SurfaceView,而这个Window的顶层View是一个FrameLayout.Window参数为: private WindowM

Android进阶必备,Window机制探索

Window的概念 Android手机中所有的视图都是通过Window来呈现的,像常用的Activity,Dialog,PopupWindow,Toast,他们的视图都是附加在Window上的,所以可以这么说 --「Window是View的直接管理者.」 Window 一个顶级窗口查看和行为的一个抽象基类.这个类的实例作为一个顶级 View 添加到 Window Manager.它提供了一套标准的 UI 方法,比如添加背景,标题等等.当你需要用到 Window 的时候,你应该使用它的唯一实现类

【HAVENT原创】前端跨域一站式登录实现 ( iframe + window.name )

从网上搜集了一些资料,window.name 传输技术,关于window.name的这样一个特性:name 值在不同的页面(甚至不同域名)加载后依旧存在,并且可以支持非常长的 name 值(2MB).换句话说,name属性不会因为页面的url变化而变化,这就给跨域提供了机会.原本是 Thomas Frank 用于解决 cookie 的一些劣势(每个域名 4 x 20 Kb 的限制.数据只能是字符串.设置和获取 cookie 语法的复杂等等)而发明的(详细见原文:<Session variable

angular 拦截器

介绍:$http service在Angular中用于简化与后台的交互过程,其本质上使用XMLHttpRequest或JSONP进行与后台的数据交互.在与后台的交互过程中,可能会对每条请求发送到Server之前进行预处理(如加入token),或者是在Server返回数据到达客户端还未被处理之前进行预处理(如将非JSON格式数据进行转换):当然还有可能对在请求和响应过程过发生的问题进行捕获处理.所有这些需求在开发中都非常常见,所以Angular为我们提供了$http拦截器,用来实现上述需求. An

Android应用程序窗口(Activity)与WindowManagerService服务的连接过程分析

在前两文中,我们分析了Activity组件的窗口对象和视图对象的创建过程.Activity组件在其窗口对象和视图对象创建完成之后,就会请求与WindowManagerService建立一个连接,即请求WindowManagerService为其增加一个WindowState对象,用来描述它的窗口状态.在本文中,我们就详细分析Activity组件与WindowManagerService的连接过程. 我们从两方面来看Activity组件与WindowManagerService服务之间的连接.一方

Android应用程序窗体设计框架介绍

在Android系统中,一个Activity相应一个应用程序窗体.不论什么一个Activity的启动都是由AMS服务和应用程序进程相互配合来完毕的.AMS服务统一调度系统中全部进程的Activity启动,而每一个Activity的启动过程则由其所属进程来完毕.AMS服务通过realStartActivityLocked函数来通知应用程序进程启动某个Activity: frameworks\base\services\java\com\android\server\am\ ActivityStac

WindowManager.LayoutParams全解

WindowManager是Android中一个重要的服务(Service ).WindowManager Service 是全局的,是唯一的.它将用户的操作,翻译成为指令,发送给呈现在界面上的各个Window.Activity会将顶级的控件注册到 Window Manager 中,当用户真是触碰屏幕或键盘的时候,Window Manager就会通知到,而当控件有一些请求产生,也会经由ViewParent送回到Window Manager中.从而完成整个通信流程.整个Android的窗口机制是基

网络传入安全jwts

使用json web token 发表于Aug 13 2014 由来 做了这么长时间的web开发,从JAVA EE中的jsf,spring,hibernate框架,到spring web MVC,到用php框架thinkPHP,到现在的nodejs,我自己的看法是越来越喜欢干净整洁的web层,之前用jsf开发做view层的时候,用的primefaces做的界面显示,虽然primefaces的确提供了很大的便利,可以让开发人员专注于业务逻辑开发,这样其实就省去了前端开发的工作.而后来发现有些客户需