StrictMode使用

StrictMode使用【IT168技术】最新的Android平台中(Android2.3起),新增加了一个新的类,叫StrictMode(android.os.StrictMode)。这个类可以用来帮助开发者改进他们编写的应用,并且提供了各种的策略,这些策略能随时检查和报告开发者开发应用中存在的问题,比如可以监视那些本不应该在主线程中完成的工作或者其他的一些不规范和不好的代码。  StrictMode有多种不

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

【IT168技术】最新的Android平台中(Android 2.3起),新增加了一个新的类,叫StrictMode(android.os.StrictMode)。这个类可以用来帮助开发者改进他们编写的应用,并且提供了各种的策略,这些策略能随时检查和报告开发者开发应用中存在的问题,比如可以监视那些本不应该在主线程中完成的工作或者其他的一些不规范和不好的代码。

  StrictMode有多种不同的策略,每一种策略又有不同的规则,当开发者违背某个规则时,每个策略都有不同的方法去显示提醒用户。在本文中,将举例子说明如何使用在Android 中使用 StrictMode。

  StrictMode的策略和规则

  目前,有两大类的策略可供使用,一类是关于常用的监控方面的,另外一类是关于VM虚拟机等方面的策略。常用的监控方面的策略有如下这些:

  Disk Reads 磁盘读

  Disk Writes 磁盘写

  Network access 网络访问

  Custom Slow Code 自定义的运行速度慢的代码分析

  前面三种的意思读者应该很清楚,就是正如它们的名字所示,分别对磁盘的读和写,网络访问进行监控。而第四种的自定义慢代码分析,是仅当访问调用类的时后才触发的,可以通过这种方法去监视运行缓慢的代码。当在主线程中调用时,这些验证规则就会起作用去检查你的代码。比如,当你的应用在下载或者解析大量的数据时,你可以触发自定义运行速度慢代码的查询分析,作用很大。StrictMode可以用于捕捉发生在应用程序主线程中耗时的磁盘、网络访问或函数调用,可以帮助开发者使其改进程序,使主线程处理UI和动画在磁盘读写和网络操作时变得更平滑,避免主线程被阻塞的发生。

  而VM方面的策略重点关注如下几类:

  内存泄露的Activity对象

  内存泄露的SQLite对象

  内存泄露的释放的对象

  其中,内存泄露的Activity对象和内存泄露的SQLite对象都比较好理解,而所谓对关闭对象的检查,主要是去监那些本该释放的对象,比如应该调用close()方法的对象。

  当开发者违反某类规则时,每种策略都会有不同的方法令开发者知道当时的情况。相关的违反情况可以记录在LogCat中或者存储在DropBox中(android.os.DropBox)服务中。而常用监控类的策略还会在当违规情况发生时显示相关的对话框和当时的上下文环境,所有的这些都为了能让开发者尽快地了解程序的瑕疵,以提交程序的质量。下面分步讲解如何使用stritctmode。


  第一步 启用strictmode

  为了能在应用中启用和配置StrictMode,开发者最好尽可能在应用程序的生命周期的早段使用,方法是调用StrictMode的方法setThreadPolicy。当使用常用监控类的时候,一个最好的调用时机,是在应用中入口和activities被调用前进行。比如在一个应用程序中,可以把代码放在启动Activity类的onCreate()方法中,下面是一个代码示例,启用了当前情况下的所有策略及规则,当程序中出现违背常用的规则时,将会显示相关的提示信息窗口:

StrictMode.setThreadPolicy(new
 StrictMode.ThreadPolicy.Builder()
.detectAll() 
.penaltyLog() 
.penaltyDialog() 


打印logcat,当然也可以定位到dropbox,通过文件保存相应的log
.build()); 
StrictMode.setVmPolicy(
new
 StrictMode.VmPolicy.Builder().detectAll()
.penaltyLog() 
.build());

当然,以上代码只应在未发布上线的测试版本的应用中运行以方便监视相关的运行情况,当在生产版本上时不应该启用strictmode。因此,最佳的代码实践应该为如下的样子:

public
 void onCreate() {

if
 (DEVELOPER_MODE) {

StrictMode.setThreadPolicy(
new
 StrictMode.ThreadPolicy.Builder()
.detectDiskReads() 
.detectDiskWrites() 
.detectNetwork() 
.penaltyLog() 
.build()); 

super.onCreate(); 
}

 

 第二步 运行strictmode

  当应用启用了strictmode模式时,其实跟普通的应用没什么两样,在测试和运行时,跟平时运行普通应用程序一样就可以了。当启用了Strictmode模式时,会监视所有的程序运行情况,当发现出现重大问题或违背策略规则时,会提示用户。下面是当运行启用了strictmode模式的应用时,当发现违背规则时,显示给用户的信息,细心观察下跟普通的出错信息有什么不同吧。

09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): StrictMode policy violation; ~duration
=319
 ms: android.os.StrictMode$StrictModeDiskWriteViolation: policy
=31
 violation
=1

09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.os.StrictMode$AndroidBlockGuardPolicy.onWriteToDisk(StrictMode.java:1041
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.database.sqlite.SQLiteStatement.acquireAndLock(SQLiteStatement.java:219
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.database.sqlite.SQLiteStatement.executeUpdateDelete(SQLiteStatement.java:83
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.database.sqlite.SQLiteDatabase.updateWithOnConflict(SQLiteDatabase.java:1829
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.database.sqlite.SQLiteDatabase.update(SQLiteDatabase.java:1780
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at com.mamlambo.tutorial.tutlist.data.TutListProvider.update(TutListProvider.java:188
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.content.ContentProvider$Transport.update(ContentProvider.java:233
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.content.ContentResolver.update(ContentResolver.java:847
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at com.mamlambo.tutorial.tutlist.data.TutListProvider.markItemRead(TutListProvider.java:229
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at com.mamlambo.tutorial.tutlist.TutListFragment.onListItemClick(TutListFragment.java:99
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.support.v4.app.ListFragment$2
.onItemClick(ListFragment.java:53
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.widget.AdapterView.performItemClick(AdapterView.java:282
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.widget.AbsListView.performItemClick(AbsListView.java:1037
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.widget.AbsListView$PerformClick.run(AbsListView.java:2449
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.widget.AbsListView$1
.run(AbsListView.java:3073
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.os.Handler.handleCallback(Handler.java:587
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.os.Handler.dispatchMessage(Handler.java:92
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.os.Looper.loop(Looper.java:132
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at android.app.ActivityThread.main(ActivityThread.java:4123
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at java.lang.reflect.Method.invokeNative(Native Method)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at java.lang.reflect.Method.invoke(Method.java:491
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599
)
09
04
16
:15
:34.592
: DEBUG
/
StrictMode(15883
): at dalvik.system.NativeStart.main(Native Method

 并且会出现如下的提示窗口,提示用户:

StrictMode使用

  忽略某些规则

  应该说大部分由StrictMode产生的规则警示都应去遵守,但有时也不是所有产生的信息都表明你的程序有错误。比如,在应用程序的主线程中去快速读写磁盘其实不会对应用的性能产生太大的影响,又或者你在调试程序阶段有一些调试的代码违反了设定的规则,这些都可以忽略掉这些规则。

  忽略规则有两种方法,一种是单纯在代码中把Strictmode的代码注释掉,另外一种比较好的方法是,在需要忽略的时候和地方,增加相应的代码去让系统停止使用这些规则去检查,等开发者认为有必要检查时,再重新应用这些规则,比如:

  StrictMode.ThreadPolicy old = StrictMode.getThreadPolicy();

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

  .permitDiskWrites()

  .build());

  doCorrectStuffThatWritesToDisk();

  StrictMode.setThreadPolicy(old);

  这里首先用old来保存了当前的策略规则,然后doCorrectStuffThatWritesToDisk();

  这里,执行了一些向磁盘快速读写的操作,最后又重新启用了这些规则。

  小结

  StrictMode是一个十分有用的类,它可以很方便地应用于检查Android应用程序的性能和存在的问题。当开启这个模式后,开发者能很好地检查应用中存在的潜在问题,更多的请参考Android文档中的相关API说明。

转文

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

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

(0)
上一篇 2022年6月10日 上午11:46
下一篇 2022年6月10日 上午11:46


相关推荐

  • 使用树莓派实现的口罩检测

    使用树莓派实现的口罩检测基于树莓派3B+官方摄像头两个指示灯实现的口罩检测项目演示链接口罩检测项目地址使用的口罩检测项目是AIZOO团队实现的使用的是目标检测常用的SSD算法。(由于疫情在家连不上实验室的服务器我无法训练)项目GitHub链接AIZOO团队给出的代码在Windows上很容易以跑通。配置的环境相对比较容易。也不需要很复杂的更改代码。因为模型较小我想出要在树莓派上运行,就进行了一些尝试。但是要在树莓派上运行需要修改一些代码。树莓派配置参考链接有很多基础配置对树莓派进行换源.

    2022年6月5日
    138
  • 直插式电阻电容封装与尺寸图…[通俗易懂]

    原文地址:直插式电阻电容封装与尺寸图解作者:北极光直插式无源器件体积普遍要比贴片式要大一些,而且直插式器件在制作PCB时需要打孔,焊接工艺跟贴片式也有差别,较为麻烦,相对而言,直插式电阻电容多是面向大功率电路应用。一、直插式电阻封装及尺寸直插式电阻封装为AXIAL-xx形式(比如AXIAL-0.3、AXIAL-0.4),后面的xx代表焊盘中心间距为xx英寸,这一点在网上很多文章都没说清楚

    2022年4月12日
    469
  • 【微信小程序 | 实战开发】开发环境、测试环境和生产环境

    【微信小程序 | 实战开发】开发环境、测试环境和生产环境开发环境 一 概念二 开发环境的组成三 配置基本流程及流程总结 测试环境 一 概述 测试环境的秩序体现在以下几个环节 生产环境 线上环境 一 概述 二 上线原则总结

    2026年3月16日
    2
  • 数学建模及其基础知识详解(化学常考知识点)

    @[TOC]自动根据文章标题生成目录一、综合评价方法根据各评价方法所依据的理论基础,现代综合评价方法大致分为以下四大类:1、专家评价方法2、运筹学与其他数学方法2.1、层次分析法(AHP)2.2、模糊综合评判法(FCE)2.3、数据包络分析法(DEA)3、基于统计和经济的方法3.1、TOPSIS评价法,优化可用熵权法3.2、主次分析法和因子分析法主成分分析法通过克服相关性、重叠性,用较少的变量来代替原来较多的变量,而这种代替可以 反映原来多个变量的大部分信息,这实际上是一

    2022年4月13日
    46
  • 如何实现 MySQL 删除重复记录并且只保留一条

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:千g blog.csdn.net/n950814abc/article/details/82284838 最近…

    2021年6月26日
    70
  • Dubbo负载均衡策略之最小活跃策略

    Dubbo负载均衡策略之最小活跃策略今天我来学习一下Dubbo负载均衡之一的最小活跃策略-LeastActiveLoadBalance首先,让我们对负载均衡做一个简单的介绍。所谓集负载均衡,其含义就是指将负载(工作任务)进行平衡、分摊到多个操作单元上进行运行。负载均衡、集群容错、服务降级这三个概念在微服务中非常重要。从调用顺序来看,一次完整的RPC调用首先是负载均衡、其次是集群容错、最后是服务降级:负载均衡解决了选哪一个的问题、集群容错解决了换哪一个的问题、而服务降级则是解决了全错了怎么办的问题今天我们要学习的策略是最小活跃策略-Le

    2022年7月11日
    21

发表回复

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

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