​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的话,就应该想办法处理这个了