热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

优化AndroidBroadcastReceiver时需关注的关键事项与最佳实践

在优化Android中的BroadcastReceiver时,开发者应关注若干关键事项并遵循最佳实践。本文探讨了在BroadcastReceiver中编码时可能遇到的意外异常及其解决方法,同时提供了提高性能和稳定性的建议。通过合理配置和使用BroadcastReceiver,可以有效避免常见的问题,如内存泄漏、响应延迟等,确保应用的高效运行。

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

今天在 android 的 BroadcastReceiver 里面写一些代码的时候出现了意想不到的异常。情况是这样的:

当我在广播类里面这样定义一个Dialog,然后再在这个类里面调用dimiss方法时,对话框始终不消失,这让我纳闷了很久。。。

 private ProgressDialog dialogDataUpload = null;private void dimiss() {if (dialogDataUpload != null) {dialogDataUpload.dismiss();dialogDataUpload = null;}}

后来仔细端详这个类里面的dimiss方法,发现 Eclipse有一个警告:“This Handler class should be static or leaks might occur”,这让我隐约联想到了以前看到的关于 BroadcastReceiver 的注意事项。后来通过详细地了解 BroadcastReceiver,发现其生命周期只有十秒左右,如果在 onReceive() 内做超过十秒内的事情,就会报ANR(Application No Response) 程序无响应的错误信息,如果需要完成一项比较耗时的工作 , 应该通过发送 Intent 给 Service, 由Service 来完成 . 这里不能使用子线程来解决 , 因为 BroadcastReceiver 的生命周期很短 , 子线程可能还没有结束BroadcastReceiver 就先结束了 .BroadcastReceiver 一旦结束 , 此时 BroadcastReceiver 的所在进程很容易在系统需要内存时被优先杀死 , 因为它属于空进程 ( 没有任何活动组件的进程 ). 如果它的宿主进程被杀死 , 那么正在工作的子线程也会被杀死 . 所以采用子线程来解决是不可靠的。

通过这段解释,让我明白了出现的问题应该是由于我执行了超过10秒的操作,所以在执行取消对话框的操作时广播类的对象已销毁,这样 dimiss 方法肯定不起作用了。所以,我的解决方法是在申明的 Dialog 前面加上 static 属性,这样当广播的生命周期已结束时,由于 static 的属性,dimiss方法就会起作用了。当然最好的办法是按照前面说的,如果是比较耗时的操作,最好启动一个 Service 来处理。


转:https://my.oschina.net/u/1460984/blog/305134



推荐阅读
author-avatar
艾你如斯i
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有