StrictMode 嚴格模式應用

Android 2.3提供一個稱為嚴苛模式(StrictMode)的調(diào)試特性,Google稱該特性已經(jīng)使數(shù)百個Android上的Google應用程序受益步责。那它都做什么呢?它將報告與線程及虛擬機相關(guān)的策略違例禀苦。一旦檢測到策略違例(policy violation)蔓肯,你將獲得警告,其包含了一個棧trace顯示你的應用在何處發(fā)生違例振乏。你可以強制用警告代替崩潰(crash)蔗包,也可以僅將警告計入日志,讓你的應用繼續(xù)執(zhí)行慧邮。策略的細節(jié)尚難確定调限,可以期待隨Android的成熟Google將增加更多策略舟陆。

主要采用采用ThreadPolicy(線程策略)和VmPolicy(Vm策略)進行檢測,各策略檢測內(nèi)容如下:

ThreadPolicy 線程策略檢測的內(nèi)容有

  • 自定義的耗時調(diào)用 使用 detectCustomSlowCalls() 開啟
  • 磁盤讀取操作 使用 detectDiskReads() 開啟
  • 磁盤寫入操作 使用 detectDiskWrites() 開啟
  • 網(wǎng)絡(luò)操作 使用 detectNetwork() 開啟
  • 資源類型不匹配 使用detectResourceMismatches() 開啟 android 23 開始增加

VmPolicy 虛擬機策略檢測的內(nèi)容有

  • Activity泄露 使用 detectActivityLeaks() 開啟
  • 未關(guān)閉的Closable對象泄露 使用 detectLeakedClosableObjects() 開啟
  • 泄露的Sqlite對象 使用 detectLeakedSqlLiteObjects() 開啟
  • 網(wǎng)絡(luò)流量監(jiān)控 使用 detectCleartextNetwork() android 23增加
  • 廣播或者服務(wù)等未注銷導致泄漏 使用 detectLeakedRegistrationObjects()開啟 android 23增加
  • 文件uri暴露 使用detectFileUriExposure() android增加

要注意anroid 23新增加的幾個策略檢測

  • android 23 以后傳遞軟件包網(wǎng)域外的 file://URI 可能給接收器留下無法訪問的路徑耻矮。 因此秦躯,嘗試傳遞 file://URI 會觸發(fā) FileUriExposedException。 分享私有文件內(nèi)容的推薦方法是使用 FileProvider裆装。
    如果不使用FileProvider時踱承,而且開啟了嚴格模式,則必須關(guān)閉detectFileUriExposure()
  • 建議在使用的直接調(diào)用detectAll(),而不是依次開啟檢測具體的策略
  • 而且嚴格模式StrictMode建議在調(diào)試模式中開啟哨免,防止影響正常運行

StrictMode具體使用:

StrictMode建議在application 的onCreate()的方法中調(diào)用茎活;

StrictModeHelper.setPolicy(BuildConfig.DEBUG);

調(diào)試時才開啟,而且利用BuildConfig屬性是否app在調(diào)試模式

public class StrictModeHelper {
    public static void setPolicy(Boolean isDebug) {
        if (isDebug && Build.VERSION.SDK_INT >= 9) {
            setThreadPolicy();
            setVmPolicy();
        }
    }

    //線程策略檢測
    private static void setThreadPolicy() {
        StrictMode.ThreadPolicy.Builder builder = new StrictMode.ThreadPolicy.Builder()
                .detectAll() //detectAll() 檢測下述所有
//                .detectCustomSlowCalls()   //自定義耗時調(diào)用
//                .detectDiskReads()         //磁盤讀取操作
//                .detectDiskWrites()        //磁盤寫入操作
//                .detectNetwork()            //網(wǎng)絡(luò)操作
//                .detectResourceMismatches()  //資源類型不匹配 android 23增加
                .penaltyLog();                 //打印logcat铁瞒,當然也可以定位到dropbox妙色,通過文件保存相應的log
        StrictMode.setThreadPolicy(builder.build());
    }

    //虛擬機策略檢測
    private static void setVmPolicy() {
        StrictMode.VmPolicy.Builder builder = new StrictMode.VmPolicy.Builder()
                .detectAll()                         //檢測下述所有
//                .detectActivityLeaks()             //Activity泄漏
//                .detectLeakedClosableObjects()     //未關(guān)閉Closable對象泄漏
//                .detectLeakedSqlLiteObjects()      //SqlLite對象泄漏
//                .detectCleartextNetwork()           //網(wǎng)絡(luò)流量監(jiān)控 android 23增加
//                .detectLeakedRegistrationObjects()   //廣播或者服務(wù)等未注銷導致泄漏  android 23增加
//                .detectFileUriExposure()             //文件uri暴露   android增加
                .penaltyLog();                        //打印logcat,當然也可以定位到dropbox慧耍,通過文件保存相應的log
        StrictMode.setVmPolicy(builder.build());
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末身辨,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子芍碧,更是在濱河造成了極大的恐慌煌珊,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,743評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件泌豆,死亡現(xiàn)場離奇詭異定庵,居然都是意外死亡,警方通過查閱死者的電腦和手機踪危,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評論 3 385
  • 文/潘曉璐 我一進店門蔬浙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人贞远,你說我怎么就攤上這事畴博∩骜” “怎么了诗力?”我有些...
    開封第一講書人閱讀 157,285評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長搂漠。 經(jīng)常有香客問我袱结,道長亮隙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,485評論 1 283
  • 正文 為了忘掉前任垢夹,我火速辦了婚禮溢吻,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘果元。我一直安慰自己煤裙,他們只是感情好掩完,可當我...
    茶點故事閱讀 65,581評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著硼砰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪欣硼。 梳的紋絲不亂的頭發(fā)上题翰,一...
    開封第一講書人閱讀 49,821評論 1 290
  • 那天,我揣著相機與錄音诈胜,去河邊找鬼豹障。 笑死,一個胖子當著我的面吹牛焦匈,可吹牛的內(nèi)容都是我干的血公。 我是一名探鬼主播,決...
    沈念sama閱讀 38,960評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼缓熟,長吁一口氣:“原來是場噩夢啊……” “哼累魔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起够滑,我...
    開封第一講書人閱讀 37,719評論 0 266
  • 序言:老撾萬榮一對情侶失蹤垦写,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后彰触,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體梯投,經(jīng)...
    沈念sama閱讀 44,186評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,516評論 2 327
  • 正文 我和宋清朗相戀三年况毅,在試婚紗的時候發(fā)現(xiàn)自己被綠了分蓖。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,650評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡尔许,死狀恐怖么鹤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情母债,我是刑警寧澤午磁,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站毡们,受9級特大地震影響迅皇,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜衙熔,卻給世界環(huán)境...
    茶點故事閱讀 39,936評論 3 313
  • 文/蒙蒙 一登颓、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧红氯,春花似錦框咙、人聲如沸咕痛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽茉贡。三九已至,卻和暖如春者铜,著一層夾襖步出監(jiān)牢的瞬間腔丧,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評論 1 266
  • 我被黑心中介騙來泰國打工作烟, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留愉粤,地道東北人。 一個月前我還...
    沈念sama閱讀 46,370評論 2 360
  • 正文 我出身青樓拿撩,卻偏偏與公主長得像衣厘,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子压恒,可洞房花燭夜當晚...
    茶點故事閱讀 43,527評論 2 349

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,777評論 25 707
  • Android 2.3提供一個稱為嚴苛模式(StrictMode)的調(diào)試特性影暴,Google稱該特性已經(jīng)使數(shù)百個An...
    Ten_Minutes閱讀 842評論 0 2
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)涎显,斷路器坤检,智...
    卡卡羅2017閱讀 134,633評論 18 139
  • 之前做傳感網(wǎng)一直在tinyOS系統(tǒng)下,contiki只是稍微了解期吓,近來實驗室突然接到contiki下的一個項目早歇,所...
    TW妖妖閱讀 1,416評論 0 2
  • 最近我在著手將一個用C++寫的線路優(yōu)化算法整合進node.js服務(wù)端,嘗試了多種方法讨勤,包括本地編譯箭跳、調(diào)用動態(tài)鏈接庫...
    PhilicX閱讀 4,355評論 1 2