StrictMode 严格模式

StrictMode 严格模式

开发者经常会无意地犯些错误:在主线程读写磁盘、访问网络,严格模式能够把帮助开发者监控这些错误。

注意:严格模式是一种保护机制但是并不保证找出所有的磁盘和网络访问。因为严格模式经常在发生Binder Call的时候报告自己的状态,所以它是一种尽力而为的机制。一般地,网络和磁盘访问一般走JNI调用,所以不一定会触发它。还有一点,线上的应用不应该开启严格模式。

代码示例:
 public void onCreate() {
     if (DEVELOPER_MODE) {
         StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()
                 .detectDiskReads()
                 .detectDiskWrites()
                 .detectNetwork()   // or .detectAll() for all detectable problems
                 .penaltyLog()
                 .build());
         StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()
                 .detectLeakedSqlLiteObjects()
                 .detectLeakedClosableObjects()
                 .penaltyLog()
                 .penaltyDeath()
                 .build());
     }
     super.onCreate();
 }

严格模式下的两种策略

StrictMode.ThreadPolicy(作用于特定线程)
主要监控以下内容:
  Disk Reads 磁盘读
  Disk Writes 磁盘写
  Network access 网络访问
  Custom Slow Code 自定义的运行速度慢的代码分析

StrictMode.VmPolicy(作用于整个虚拟机进程的所有线程)
主要监控以下内容:
  内存泄露的Activity对象
  内存泄露的SQLite对象
  内存泄露的释放的对象
  内存泄漏的BroadcastReceiver or ServiceConnection

严格模式监控到异常信息触发的提示

Log 日志
  Death 应用退出
  DropBox 持久化的、系统级别的Logcat

测试

代码

package com.jinglong.strickmodetest;

    import android.os.Bundle;
    import android.os.Environment;
    import android.os.StrictMode;
    import android.support.v7.app.AppCompatActivity;
    import android.util.Log;

    import java.io.File;
    import java.io.FileReader;
    import java.io.FileWriter;
    import java.io.IOException;

    public class MainActivity extends AppCompatActivity {

        public static final String STRICK_MODE_TEST = "StrickModeTest";
        public static final String TAG = STRICK_MODE_TEST + ":" +MainActivity.class.getName();
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);

            StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectAll().penaltyLog().build());
            StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder().detectAll().penaltyLog().build());
            File externalStorageDirectory = Environment.getExternalStorageDirectory();
            if (externalStorageDirectory==null||!externalStorageDirectory.exists()){
                Log.d(TAG,"SDCard is not exist");
            }else{
                //获取SD卡下的文件或目录
                String[] childrenFiles = externalStorageDirectory.list();
                for (int i = 0;i < childrenFiles.length;i++){
                    File childFile = new File(externalStorageDirectory.getPath(),childrenFiles[i]);
                    if (childFile.exists()&&childFile.isFile()){
                        //找到第一个File
                        try {
                            FileReader fr = new FileReader(childFile);
                            char ch[] = new char[1024] ;
                            while (fr.read(ch)!=-1){
                                Log.e(TAG,new String(ch));
                            }
                            //为了测试效果,此处不关fr

                            FileWriter fw = new FileWriter(childFile);
                            fw.write("Hello 璟龙");
                            fw.flush();
                            //为了测试效果,此处不关fw
                            
                            break;
                        } catch (IOException e) {
                            e.printStackTrace();
                        }
                    }
                }
            }
        }
    }

日志

  • 第一条日志表示资源没有关闭,即IO流未关闭
  • 第二条日志表示在主线程中发生了磁盘访问的读操作
07-18 15:05:26.930 10735-10748/com.jinglong.strickmodetest E/StrictMode: A resource was acquired at attached stack trace but never released. See java.io.Closeable for information on avoiding resource leaks.
07-18 15:05:26.949 10735-10735/com.jinglong.strickmodetest D/StrictMode: StrictMode policy violation; ~duration=44 ms: android.os.StrictMode$StrictModeDiskReadViolation: policy=31 violation=2
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • StrictMode是Android2.3加入的一个工具类,用于帮助开发者发现代码中的一些不规范的问题。比如网络操...
    Kokonuts阅读 873评论 0 0
  • Android 2.3提供一个称为严苛模式(StrictMode)的调试特性,Google称该特性已经使数百个An...
    Jinwong阅读 3,970评论 0 2
  • 只要我们是人,我们一定会犯错误。 如果有勇气承认错误,总是可以原谅的:李小龙 那么,你如何知道和纠正在Androi...
    FynnJason阅读 2,747评论 0 11
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,169评论 11 349
  • 今天本休,也是情人节,结婚快2年,对于这种节日显然是麻木的。 照例睡到中午,起床,洗漱整理完毕,带上书本,做上...
    十叁少阅读 201评论 0 0