strictmode android,Android中的StrictMode

strictmode android,Android中的StrictModeStrictMode.ThreadPolicypublicstaticfinalclassStrictMode.ThreadPolicyextendsObjectjava.lang.Object↳android.os.StrictMode.ThreadPolicy介绍StrictMode是Android2.3(API9)中引入的一个工具类,继承自Object,它可以检测代码中的一…

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

StrictMode.ThreadPolicy

public static final class StrictMode.ThreadPolicy

extends Object

java.lang.Object

↳ android.os.StrictMode.ThreadPolicy

介绍

StrictMode是Android2.3(API9)中引入的一个工具类,继承自Object,它可以检测代码中的一些不规范问题,其实和AS的静态代码检测(Inspect code)挺像的,最常用来捕获应用的主线程上的网络访问或者文件读写操作,以及一些内存泄漏,而这些耗时操作会影响着应用的性能.严重时会出现ANR,开发中及时发现这些问题,我们可以使用StrictMode,检测出代码中的问题,最终优化改善代码质量;

StrictMode主要检测什么?

严格模式主要检测俩方面问题:

线程策略(ThreadPolicy);

VM策略(vmPolicy);

ThreadPolicy策略:

detectNetwork()检测网络操作;

detectDiskReads()检测磁盘读取操作;

detectCustomSlowCalls()自定义耗时操作;

detectUnbufferedIo()检测未缓冲IO流;

detectResourceMismatches()检测资源不匹配;

detectDiskWrites()检测磁盘写入操作;

penaltyDialog()弹出违规提示窗;

penaltyLog()在log日志中打印违规信息;

detectAll()开启所有detect系列方法;

VmPolicy策略:

setClassInstanceLimit(Class klass, int instanceLimit)检测类的实例数量;

detectActivityLeaks()检测activity泄漏;

detectAll()开启所有detect系列方法;

detectLeakedSqlLiteObjects()检测splite对象;

detectLeakedClosableObjects()检测sqlite操作未关闭的游标对象泄漏;

detectLeakedRegistrationObjects()检测注册未解除的对象;(service、boradcast)

detectFileUriExposure()检测fileProvider;

detectCleartextNetwork()检测网络的传输的明文数据;

detectContentUriWithoutPermission()检测contentProvider的权限;

detectUntaggedSockets()程序中没有标记的套接字;

penaltyLog()在log中打印违规日志;

penaltyDialog()弹出违规提示窗;

ps:相应的permit都是关闭该项检测;

示例代码:

public class StrictModeUtil {

public static void threadMethod(){

StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()

.detectAll()//开启所有的detectXX系列方法

//.penaltyDialog()//弹出违规提示框

.penaltyLog()//在Logcat中打印违规日志

.build());

}

public static void momeryMethod(){

StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()

.detectActivityLeaks()//检测Activity泄露

.penaltyLog()//在Logcat中打印违规日志

.detectAll()

.build());

}

}

用法:

可以放在Application或者Activity以及其他组件的onCreate方法中调用,我是放在了Activity中的onCreate方法中,说明一点,严格模式最好只在开发版本中使用,线上版本最好关掉;

代码中调用:

@Override

protected void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

TestUtil.momeryMethod();

TestUtil.threadMethod();

StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder().setClassInstanceLimit(FragmentCreateRouter.class, 1).penaltyLog().build());

}

运行程序,可以在控制台的log中过滤自己的信息,严格模式会上报多种类型的问题,所以我们直接通过筛选StrictMode关键信息;

669c2afec298?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

根据信息提示,我们可以发现一些代码不规范的问题,日志中的~duration=20ms并不是耗时执行了20ms,如果想知道耗时执行时间,可以用自定义耗时方法,自己打印时间.此处是在主线程中进行IO的写的操作,但是因为是业务需要,所以这点就忽略了,其实,严格模式上报的问题类型很多,还要根据具体的业务场景来判断是否需要更改.

如果检测出内存泄漏,会提示:

04-11 12:25:45.659 27799-27799/com.xxx.xxx D/StrictMode: StrictMode policy violation: android.os.strictmode.InstanceCountViolation: class xxxxxxxxxActivity; instances=2; limit=1

at android.os.StrictMode.setClassInstanceLimit(StrictMode.java:1)

只是能看出某一个类发生的内存泄漏,但是并不能找出具体信息,所以,这点严格模式还是满足不了问题排查的;我们可以通过Leaks或者MAT等工具进一步排查;

其实Android手机的开发者模式中,也有严格模式选项,开启之后,如果主线程中有耗时操作,设备屏幕则会闪烁,很直观;

注意事项:

1、StrictMode只在开发阶段排查使用,生产阶段禁用;

2、严格模式无法控制JNI中的耗时操作;

3、应用的违例情况并非全部要解决,比如有些IO操作确实要在主线程中进行;

4、违例操作弹窗提示,这个不好用啊,建议关掉;

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言网络编程聊天系统_用户程序在用户态下使用系统调用

    c语言网络编程聊天系统_用户程序在用户态下使用系统调用一、socket介绍socket起源于linux,在Linux中,一个非常重要的思想就是“一切皆文件”,一切行为皆可描述为“打开文件>读写文件>关闭文件”,socket可以理解成一种

    2022年8月1日
    4
  • wxpython使用简介_wxPython 教程(一) 简介[通俗易懂]

    wxpython使用简介_wxPython 教程(一) 简介[通俗易懂]应用(application)是用来执行特定任务或一组任务的电脑程序。网页浏览器、媒体播放器、文字处理程序都是典型的应用样例。不同应用可以划分至四种不同的应用领域:在线商店应用、wiki、微博等都是受欢迎的网页(web)应用,我们通过网页浏览器可以访问它们。桌面(Desktop)应用的例子则包括Maya、Opera、OpenOffice或Winamp。企业级(Enterprise)应用则指复…

    2022年5月21日
    32
  • linux objdump命令,Linux objdump命令

    linux objdump命令,Linux objdump命令一、简介objdump命令是用查看目标文件或者可执行的目标文件的构成的gcc工具。二、选项三、实例1)显示文件头信息objdump-ftest2)显示SectionHeader信息objdump-htest3)显示全部Header信息objdump-xtest4)显示全部Header信息,并显示对应的十六进制文件代码objdump-stest5)输出目标文件的符号表objdump…

    2025年6月24日
    4
  • 强化学习 模仿学习 于robot[通俗易懂]

    强化学习 模仿学习 于robot[通俗易懂]写在前面:分享知识是再好不过的事情。这篇文章主要是总结自己最近看的一些文章以及相关知识。自己在暑假实习的时候学习的就是在物理仿真平台上做robot的强化学习,未来读PhD的时候也被老师继续分配到了这个方向,哈哈。可能要一直从入门到入土了,趁着最近写researchproposal的时候,将最近的理解记录一下。鉴于笔者知识水平有限,若有不妥当之处,还请指出。摘要:robot强化学习模仿学…

    2026年1月27日
    2
  • API之FindWindowEx和SendMessage

    API之FindWindowEx和SendMessage最近在VC6.0开发中碰到了两个函数,经过一番搜索查阅,特记录于此。

    2022年5月27日
    37

发表回复

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

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