天天看点

android WIN DEATH

​​http://blog.sina.com.cn/s/blog_46846ade0101cixq.html​​

android WIN DEATH: Window{4283f3f8 xxx.xxx.xxx paused=false}

当日志中出现这么个东西的时候,很难找到问题具体挂在哪里,有时候很难重现这个问题,经测试总算知道原因了。

大概有某个东西,被设置了个Context,而经常可能就是把个Activity作为Context传进去了,然后可能由于用户操作退出了那个Activity,所以那个Activity就释放了(准确说应该是从WindowManager里面移除了,不一定从内存释放),再然后,前面那个保留了Context的东西,又做了某种依赖Context的操作,而且极可能是跟显示有关的,然后,就报这个问题了。

一个简单的例子:

一个单例,TestManager

一个Actvity TempActivity

在TempActivity的onCreate里面写TestManager.setContext(this)

在TestManager里面的方法

void setContext(Context con){
 
this.context = con;
 
new Thread(){
 
  void run(){
 
  wait(10000);  //等10秒
 
  Dialog dialog = new Dialog(con);
 
  dialog.show();
 
}
 
}.start();
 
}      

大概意思这样,然后TempActivity不要是唯一的一个Activity,它应该是由AActivity进去的

然后做这个操作,先进入AActivity,然后进入TempActivity,然后很快退出TempActivity,在AActivity界面等大概10秒,然后就会出这个问题了。

有了这个思路,其实找到那些dialog的show去catch一下就不会报问题了,不过如果一定要show的话,就应该想办法处理这个了