ANR log 日志的抓取

【Android】抓取log(anr)

1、anr问题的log一般都在/data/anr/目录下,使用如下命令即可导出log

adb pull /data/anr/traces.txt   d:/     =》意思是将手机上的traces.txt导出到电脑的d目录下

但是也会有该命令失效的时候。你能adb shell ls /data/anr/  看到该文件,但是导出时会提示该文件不存在,原因没有去跟,但是导出的方式可以如下:

1、adb shell 

2、cat  /data/anr/xxx   >/mnt/sdcard/yy/zz.txt   

3、exit

4、adb pull /mnt/sdcard/yy/zz.txt  d:  ,即可将文件导出到了d盘。

==============================================================================

ANRs (“Application Not Responding”),意思是”应用没有响应“。


 

在如下情况下,Android会报出ANR错误:

– 主线程 (“事件处理线程” / “UI线程”) 在5秒内没有响应输入事件

– BroadcastReceiver 没有在10秒内完成返回

通常情况下,下面这些做法会导致ANR

 

1、在主线程内进行网络操作

2、在主线程内进行一些缓慢的磁盘操作(例如执行没有优化过的SQL查询)

应用应该在5秒或者10秒内响应,否则用户会觉得“这个应用很垃圾”“烂”“慢”…等等

逻辑应该是
1. new出一个新的线程,进行数据请求
2. 获取数据后,调用handler.sendMessage方法
3. 在handler的handle()方法中更新UI

 

这样就可以,或者也可以这样
private Thread mthread;
private Handler mhandler;
oncreate:
mthread = new Thread(runnable);//这里是在主线程中创建一个子线程,不会阻塞UI
mthread.start();

private Runnable runnable = new Runnable (){
           void run(){
                //做耗时的数据处理
                //处理完毕
                mhandler.sendEmptyMessge(1000);//这里发消息通知UI可以更新了
           }

};

mhandler = new Handler(){
              void handleMessgae(Message msg){
                    if(msg.what == 1000){
                        //更新UI
                    }
                    super.handlMessgae();
              }
};


你可能感兴趣的:(android技术)