标签:
如果MainThread长时间无响应,系统会提示“XXX无响应”,然后用户会关闭。那么,如何定位问题呢?无响应并不像Crash,它抓取不到异常日志,通常我们需要调试,才能定位问题。如何调试呢?
1.在Eclipse Devices窗口,选中app对应的包名,然后点击debug图标(绿色的小虫子),然后切换到Debug视图
2.切换视图之后,可以看到debug下,app的线程列表
3.对于main线程(第一个线程),选中,并将其挂起Suspend
4.然后我们就可以看到,Suspend之后,main线程卡住的位置:
可以看出,main线程在调用pauseBubbleAndHide时,surfaceView无法lockCanvas造成页面卡住。经后续排查发现,在掉用这个方法之前,lockCanvas和unlockCanvasAndPost没有成对出现照成的,上一次lock之后,没有unlock,照成再次lockCanvas时,无法响应。然后解决问题。
以上介绍了调试程序无响应的步骤。
-------------------------------------------------------------------
更多交流,Android开发联盟QQ群:272209595
标签:
原文地址:http://blog.csdn.net/nupt123456789/article/details/43274611