strictmode android,Android StrictMode使用「建议收藏」

strictmode android,Android StrictMode使用「建议收藏」StrictMode是Android提供的一个开发工具,用于检测一些异常的操作,以便开发者进行修复。StrictMode可以监控以下问题,不应该在应用主线程中完成的工作,包括磁盘读写、网络访问等。内存泄露,包括Activity泄露、SQLite泄露、未正确释放的对象等。使能StrictMode通常在Application和Activity的开始处(如onCreate)添加代码使能StrictMod…

大家好,又见面了,我是你们的朋友全栈君。

StrictMode是Android提供的一个开发工具,用于检测一些异常的操作,以便开发者进行修复。StrictMode可以监控以下问题,

不应该在应用主线程中完成的工作,包括磁盘读写、网络访问等。

内存泄露,包括Activity泄露、SQLite泄露、未正确释放的对象等。

使能StrictMode

通常在Application和Activity的开始处(如onCreate)添加代码使能StrictMode,

public void onCreate() {

if (DEVELOPER_MODE) {

StrictMode.setThreadPolicy(new ThreadPolicy.Builder()

.detectDiskReads()

.detectDiskWrites()

.detectNetwork() // or .detectAll() for all detectable problems

.penaltyLog()

.build());

StrictMode.setVmPolicy(new VmPolicy.Builder()

.detectLeakedSqlLiteObjects()

.detectLeakedClosableObjects()

.penaltyLog()

.penaltyDeath()

.build());

}

super.onCreate();

}

开启StrictMode需要进行两方面的设置:ThreadPolicy和VmPolicy。两种策略中以“detect”开头命名的方法代表需要检测的问题,以“penalty”开头命名地 方法代表探测到问题后的处理方式。

ThreadPolicy为线程方面使用的策略,包括磁盘读写检测,网络访问检测等。

VmPolicy为VM相关的策略,用于检测内存泄露,未释放的对象等。

两种策略中使用的主要方法如下,

ThreadPolicy

detectAll()

检测所有潜在的问题

detectCustomSlowCalls()

检测慢速调用

detectDiskReads()

检测磁盘读操作

detectDiskWrites()

检测磁盘写操作

detectNetwork()

检测网络操作

detectResourceMismatches()

检测定义资源类型和getter调用之间的不匹配

detectUnbufferedIo()

检测未缓存的I/O操作

penaltyDeath()

检测到问题后crash整个进程

penaltyDeathOnNetwork()

检测到问题后crash任何使用网络的进程

penaltyDialog()

检测到问题后弹出对话框

penaltyDropBox()

检测到问题后将堆栈和数据写到DropBox中

penaltyFlashScreen()

检测到问题后闪烁屏幕

penaltyLog()

检测到问题后记录到系统日志中。

VmPolicy

detectAll()

检测所有潜在的问题

detectActivityLeaks()

检测Activity内存泄露

detectCleartextNetwork()

检测未使用SSL / TLS打包的任何网络传输

detectContentUriWithoutPermission()

检测未设置读写权限的”content://Uri”传输

detectFileUriExposure()

检测“file://Uri”传输

detectLeakedClosableObjects()

检测对象未正常关闭。

detectLeakedRegistrationObjects()

检测BroadcastReceiver或ServiceConnection在Context拆卸时发生的泄露

detectLeakedSqlLiteObjects()

检测SQLite对象未正常关闭

detectNonSdkApiUsage()

检测非Android SDK API的反射用法。

detectUntaggedSockets()

检测未使用TrafficStats标记的套接字

penaltyDeath()

检测到问题后crash整个进程

penaltyDeathOnCleartextNetwork()

检测到问题后crash任何使用网络的进程

penaltyDeathOnFileUriExposure()

当“file://Uri”暴露在应用之外时,crash整个进程

penaltyDropBox()

检测到问题后将堆栈和数据写到DropBox中

penaltyLog()

检测到问题后记录到系统日志中。

setClassInstanceLimit(Class klass, int instanceLimit)

设置同时在内存中存储一个类实例的上限。

检查StrictMode的结果

当在策略中设置penaltyLog()时,可以在系统log中打印相关log,可以使用”adb logcat -s StrictMode“进行查看。例如下面这段log,说明涉嫌违规的操作是StrickMode:DiskReadViolation,耗时48ms。

D StrictMode: StrictMode policy violation; ~duration=48 ms: android.os.StrictMode$StrictModeDiskReadViolation: policy=4390919 violation=2

at android.os.StrictMode$AndroidBlockGuardPolicy.onReadFromDisk(StrictMode.java:1263)

at android.database.sqlite.SQLiteConnection.applyBlockGuardPolicy(SQLiteConnection.java:1039)

at android.database.sqlite.SQLiteConnection.executeForCursorWindow(SQLiteConnection.java:840)

at android.database.sqlite.SQLiteSession.executeForCursorWindow(SQLiteSession.java:836)

at android.database.sqlite.SQLiteQuery.fillWindow(SQLiteQuery.java:62)

at android.database.sqlite.SQLiteCursor.fillWindow(SQLiteCursor.java:143)

at android.database.sqlite.SQLiteCursor.getCount(SQLiteCursor.java:132)

at android.database.AbstractCursor.moveToPosition(AbstractCursor.java:219)

at android.database.AbstractCursor.moveToNext(AbstractCursor.java:268)

at com.gm.android.emojistore.provider.EmojiStoreProvider.handleEtxetQuery(EmojiStoreProvider.java:108)

at android.content.ContentProvider.query(ContentProvider.java:1017)

at android.content.ContentProvider$Transport.query(ContentProvider.java:238)

at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:112)

at android.os.Binder.execTransact(Binder.java:453)

当在设备端通过设置打开严格模式时,出现违规操作时屏幕会闪烁。

设置-》开发人员选项-》监控-》启用严格模式

当在策略中设置penaltyDropBox() 时,出现违规操作时会在/data/system/dropbox/下生成文件。文件包括system_app_strictmode 和 data_app_strictmode两种,内容包括问题发生时的堆栈和进程相关信息。

参考文档:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134259.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月2日 下午3:20
下一篇 2022年5月2日 下午3:40


相关推荐

  • c语言dlsym函数_dlsym

    c语言dlsym函数_dlsym2019独角兽企业重金招聘Python工程师标准>>>…

    2025年5月31日
    6
  • phpStudy2016 配置多个域名期间遇到的问题

    phpStudy2016 配置多个域名期间遇到的问题

    2021年10月10日
    48
  • kill命令杀死所有进程_linux 杀死进程

    kill命令杀死所有进程_linux 杀死进程1kill:根据进程号(PID)杀死进程在linux上,一般常用的杀死进程的命令是kill,但是也有缺陷,下面说1、查看指定名称的进程,如下我查看运行python程序的进程pythonaux|greppython2、根据进程号(PID)杀死进程:第二列显示的就是进程号killPID3、强制杀死进程,有些进程可能杀不死,就加个-9参数,强制让它死掉!kill-9PID5、杀死多个进程,在后面跟多个进程的PID号即可kill-9PID1PID2PID3…

    2025年7月10日
    6
  • 使用两个栈实现一个队列

    使用两个栈实现一个队列题目 使用两个栈实现一个队列 栈 后进先出 队列 先进先出 入队列 直接入栈 1 出队列 返回队列的队尾元素 返回队列的队头元素 队列为空 栈 1 为空 amp amp amp amp amp amp amp amp amp amp 栈 2 为空 队列元素个数 栈 1 的元素个数 栈 2 的元素个数 参考代码 设置一个队列由两个栈组成 typedefstruc

    2026年3月19日
    1
  • 免费开放api接口_免费API

    免费开放api接口_免费API抖音短视频无水印解析:http://api.63code.com/douyin2、皮皮虾视频无水印解析:http://api.63code.com/pipixia3、b站视频解析:http://api.63code.com/bili4、必应每日壁纸:http://api.63code.com/bing5、网易云音乐解析:http://api.63code.com/wyy6、垃圾分类查询:http://api.63code.com/garbage7、icp备案查询:http://…

    2026年4月17日
    3
  • pycharm设置断点单步运行_pycharm怎么debug

    pycharm设置断点单步运行_pycharm怎么debug在我们平时写程序的时候,简单的程序一眼就能看出问题所在,但是稍微大一点的程序,就很难在茫茫代码中找到一个参数的失误带来的bug,所以我们引入debug单步调试。一、常用操作F8:stepover单步遇到断点后,程序停止运行,按F8单步运行。不进入调用函数内部F7:stepinto进入配合F8使用。单步调试F8时,如果某行调用其他模块的函数,在此执行F7,可以进入函数内部,如果是F…

    2022年8月27日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号