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里面的方法
大概意思这样,然后TempActivity不要是唯一的一个Activity,它应该是由AActivity进去的
然后做这个操作,先进入AActivity,然后进入TempActivity,然后很快退出TempActivity,在AActivity界面等大概10秒,然后就会出这个问题了。
有了这个思路,其实找到那些dialog的show去catch一下就不会报问题了,不过如果一定要show的话,就应该想办法处理这个了