Android中的StrictMode

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关键信息;


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、违例操作弹窗提示,这个不好用啊,建议关掉;

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容