anr日志导出及分析

anr发生原因

Application Not Responding(简称:ANR)指应用中一些特定的事件(如用户触摸事件、广播等)在应用的主线程没有在规定的时间内处理完,系统自动做出终止应用运行的响应。Android系统中,ActivityManagerService(简称AMS)和WindowManagerService(简称WMS)会检测App的响应时间,如果App在特定时间无法相应屏幕触摸或键盘输入时间,或者特定事件没有处理完毕,就会出现ANR。
anr出现的场景:
InputDispatching Timeout:5秒内无法响应屏幕触摸事件或键盘输入事件。
BroadcastQueue Timeout :在执行前台广播(BroadcastReceiver)的onReceive()函数时10秒没有处理完成,后台为60秒。
Service Timeout :前台服务20秒内,后台服务在200秒内没有执行完毕。
ContentProvider Timeout :ContentProvider的publish在10s内没进行完。

1、查看是否有anr文件

在命令行窗口
adb shell
ls adb /data/anr


adb查询anr日志.PNG

2、导出anr日志

法1:
在android studio terminal窗口
adb bugreport

导出anr日志.PNG

法2:
打开CMD小黑框,进入到Android SDK 目录下的platform-tools文件夹下面直接输出 : adb logcat 复制粘贴到一个txt文本下,方便稍后查看
法3:
执行adb pull /data/anr/traces.txt D:\traces.txt 输出traces日志。

anr日志分析

例1

                try {
                    Thread.sleep(9000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

在activity中按钮点击后在主线程执行sleep操作。导出的anr日志如下:


主线程sleep导致anr分析.PNG

搜索DALVIK_THREADS,找到第一个,然后看主线程main,tid是线程id。然后线程状态是Sleeping。继续往下看堆栈可以看到是因为按钮点击后sleep时间过长,导致后续点击事件无法及时处理导致。

各参数含义:
group:线程所处的线程组
sCount: 线程被正常挂起的次数
dsCount: 线程因调试而挂起次数
nice:线程的调度有优先级
utm:线程在用户态中调度时间值
stm:线程在内核态中的调度时间值
core:最后执行这个线程的CPU核序号

例2

public class MainActivity extends AppCompatActivity implements View.OnClickListener {
    private static final String TAG = "MainActivity";
    private Button button;
    private Button button2;
    private Button btnMVTest;
    private Object object= new Object();
    private MyLock myLock = new MyLock();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        findViews();
    }

    private void findViews() {
        button = findViewById(R.id.button);
        button2 = findViewById(R.id.button2);
        btnMVTest = findViewById(R.id.btnMVTest);
        button.setOnClickListener(this);
        button2.setOnClickListener(this);
        btnMVTest.setOnClickListener(this);
    }

    @Override
    public void onClick(View v) {
        int viewId = v.getId();
        switch (viewId){
            case R.id.button2:
                testBlock();
                break;
            case R.id.btnMVTest:
                Log.e(TAG, "onClick: mainThread="+Thread.currentThread().getName()+" tid="+Thread.currentThread().getId());
                doSqlQuery();
                break;
        }
    }

    private void testBlock(){
        Thread thread = new Thread(new Runnable() {
            @Override
            public void run() {
                synchronized (myLock){
                    try {
                        doSqlQuery();
                        Thread.sleep(11000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
        });
        thread.setName("DTestBlock");
        thread.start();
    }

    private void doSqlQuery(){
        synchronized (myLock){
            Log.e(TAG, "doThreadBlcok: 被锁住的函数 threadName="+Thread.currentThread().getName()+" threadId="+Thread.currentThread().getId());
        }
    }

    private class MyLock{

    }
}

看下anr日志。


主线程阻塞导致anr分析.PNG

可以看到主线程处于Blocked(阻塞)状态,为何阻塞:

- waiting to lock <0x0b19381d> (a com.example.router.MainActivity$MyLock) held by thread 3

尝试锁定MyLock实例对象,但是它被线程3所持有。


线程3sleep.PNG

线程3执行了sleep,在sleep的时间段内,没有释放对象锁。导致主线程获取不到对象锁而处于阻塞状态,后续点击事件响应不了,从而导致anr。

3、总结
anr是比较严重的性能问题,对用户体验影响较大。而且手动导出anr日志有时并没那么方便,可以考虑使用第三方性能检测工具如bugly等,简化anr的排查。

参考:
//www.greatytc.com/p/eb6826c40e05

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352