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();
              }
};

更多相关文章

  1. 【Android】Handler机制源码解析
  2. android耗时任务_handler
  3. Android(安卓)面试题
  4. Android(安卓)SQLite使用详解和多线程并发访问
  5. Android(安卓)View事件分发、拦截、消费机制
  6. Android实现文件上传下载【xUtils工具实现】
  7. Android(安卓)事件传递机制实测
  8. android binder与handler的简要理解
  9. 在 Android(安卓)通过 get_event 获得 input 设备 上报event

随机推荐

  1. mysql 5.7.23 安装配置图文教程
  2. mysql 5.7.23 winx64解压版安装教程
  3. Mysql提升大数据表拷贝效率的解决方案
  4. mysql 5.7.21 winx64绿色版安装配置方法
  5. 基于mysql+mycat搭建稳定高可用集群负载
  6. MySQL 5.7临时表空间如何玩才能不掉坑里
  7. MySQL问答系列之如何避免ibdata1文件大小
  8. MySQL问答系列之什么情况下会用到临时表
  9. 关于JDBC与MySQL临时表空间的深入解析
  10. MySQL中SQL模式的特点总结