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/cn.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灯, 水草

请输入看板名称,例如:Gossiping站内搜寻

TOP