A N R :

Application Not Responding : 应用没有响应异常

 

引发ANR的原因是,组件的主线程去执行了耗时操作多少秒,就会引发ARN异常;

 

引发ANR异常的案例:

复制代码
package com.example.administrator.myapplication;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        for (int i = 0; i < 10; i++) {
            try {
                Thread.sleep(10000);

            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }

        Toast.makeText(this, "onCreate执行完毕.....", Toast.LENGTH_SHORT).show();

    }
}
复制代码

 执行结果:此ANR异常时Android操作系统报出的,操作系统检测到组件被阻塞,认为此应用,需要结束掉了 

 

线程执行图:

 

 


 

 

 

解决方案:

在组件的主线程加入子线程,保证不影响主线程,保证不阻塞主线程,只要保证组件的主线程正常运行就不会引发ANR异常

复制代码
package com.example.administrator.myapplication;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        /**
         * 增加子线程执行耗时操作,保证主线程正常运行
         */
        new Thread(){

            @Override
            public void run() {
                super.run();

                for (int i = 0; i < 10; i++) {
                    try {
                        Thread.sleep(10000);

                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }

            }
        }.start();

        /**
         * 增加了子线程 后 不影响组件的主线程运行
         */
        
        // 提示
        Toast.makeText(this, "onCreate执行完毕.....", Toast.LENGTH_SHORT).show();

    }
}
复制代码

 

 执行结果,增加了子线程就不影响主线程运行了,从而就不会引发ANR异常:

 

 线程执行图: