Translate-CS 板


LINE

Blog 版:http://blog.dontcareabout.us/2014/04/blog-post.html 原文網址:https://plumbr.eu/blog/you-cannot-predict-the-way-you-die BBS 版以 markdown 語法撰寫 ______________________________________________________________________ 在花了一天對付另一個 [Heisenbug]:每當我快抓到原因,它就會變了樣; 我想我在這個 case 中學到的東西應該有分享的價值。 [Heisenbug]: http://en.wikipedia.org/wiki/Heisenbug 我寫了一個簡單的範例來展示這個狀況。在這個例子中, 我建立一個 `Map` 然後用無窮迴圈往裡頭狂塞 key-value: class Wrapper { public static void main(String args[]) throws Exception { Map map = System.getProperties(); Random r = new Random(); while (true) { map.put(r.nextInt(), "value"); } } } 你可能也看得出來,compile 然後執行這段程式碼是不會有什麼好下場。 正確來說,當用下面的指令執行時: java -Xmx100m -XX:+UseParallelGC Wrapper shell 就會出現 `java.lang.OutOfMemoryError: GC overhead limit exceeded`。 但如果用不同的 heap 大小、或是不同 GC, 我的 Mac OS X 10.9.2 + Oracle Hotspot JDK 1.7.0_45 會選擇不同的死法。 例如設定比較小的 heap 來執行,如下: java -Xmx10m -XX:+UseParallelGC Wrapper application 會用比較熟悉的死法, 也就是在 `Map` 調整大小時炸 `java -Xmx100m -XX:+UseParallelGC Wrapper`。 用 ParallelGC 以外的 GC 演算法, 像是 `-XX:+UseConcMarkSweepGC`、`-XX:+UseG1GC`, 炸出來的錯誤訊息是預設的 exception handler 抓到的, 因為 heap 已經耗盡,所以在 `Exception` 建立時甚至無法設定 stacktrace、 也就不會有 stacktrace: My Precious:examples vladimir$ java -Xmx100m -XX:+UseConcMarkSweepGC Wrapper Exception: java.lang.OutOfMemoryError thrown from the UncaughtExceptionHandler in thread "main" 這個故事的教訓是:你無法選擇你的 application 在資源不足的時候 會以哪一種方法掛掉,所以也無法用一系列特定的行為來推測。 在上頭的例子就可以看到有三種完全不同的失敗方式: 1. GC 內建的安全檢查失敗: 當 GC 花超過 98% 的時間在 GC 上但是沒啥效果(heap 清出的空間少於 2%), JVM 會放棄然後炸 `java.lang.OutOfMemoryError: GC overhead limit exceeded`。 2. 下一個操作無法取得更多記憶體: 每當下一個指令嘗試要求比現在 heap 可用空間還大的記憶體, 就會炸 `java.lang.OutOfMemoryError: Java heap space`。 3. 你可能已經製造過這個狀況, 當記憶體用完、JVM 無法建立一個新的 `OutOfMemoryError` instance、 也無法填 stacktrace 內容並把它送到 print stream 輸出。 如此一來錯誤會是 [UncaughtExceptionHaneler] 炸出來的, 而且不走正規的控制流程。 這個 handler 人如其名, 在 thread 因為 uncaught exception 而終止時會發揮作用。 在這類案例中,JVM 會用它的 `UncaughtExceptionHandler` 查詢 thread、 然後呼叫 handler 的 `uncaughtException()`。 所以每當你覺得抓到表示缺乏資源的錯誤時,再想一下。 系統可能處在一個脆弱的狀態,你覺得你可以倚賴的徵狀會改變或是消失。 然後過了 12 個小時,只會讓你跟我一樣眼花撩亂不知所措。 [UncaughtExceptionHaneler]: http://docs.oracle.com/javase/7/docs/api/ java/lang/Thread.UncaughtExceptionHandler.html -- 錢鍾書: 說出來的話 http://www.psmonkey.org 比不上不說出來的話 Java 版 cookcomic 版 只影射著說不出來的話 and more...... --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 114.43.107.81
※ 文章網址: http://webptt.com/m.aspx?n=bbs/Translate-CS/M.1398420653.A.762.html ※ 編輯: PsMonkey (114.43.107.81), 04/25/2014 18:12:11







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:iOS站內搜尋

TOP