异常(Exceptions)

仅仅在异常状况下才使用Exceptions
  • 不要把Exceptions用于ordinary control flow
  • 不要写这样的API: 迫使别人把Exceptions用于ordinary control flow
  • 应该写这样的API:
have a separate “state-testing” method indicating 
whether it is appropriate to invoke the state-dependent method
比如:
the Iterator interface has the state-dependent method next 
and the corresponding state-testing method hasNext 
have the state-dependent method return an empty optional 
or a distinguished value such as null 
if it cannot perform the desired computation
java throwable有哪些?
checked exceptions, runtime exceptions, errors
其中 runtime exceptions, errors 都属于unchecked exceptions
在使用java的throwable时,有哪些准则?
  • throw checked exceptions for recoverable conditions
  • 为你的checked exceptions提供methods,便于caller recoverable
  • throw unchecked exceptions for programming errors
  • 只定义checked exceptions 或 runtime exceptions,不要定义Error及其子类或其他的throwable及其子类
  • 不知道throw哪种exceptions时,就throw RuntimeException
  • Avoid unnecessary use of checked exceptions,一种消除 a checked exception的方式是return an optional of the desired result type
  • 尽量document all exceptions thrown by each method
  • exception的detail message应该包含导致该exception的所有parameters 和 fields 的值,比如IndexOutOfBoundsException的detail message包括 the lower bound, the upper bound, and the index value that failed to lie between the bounds
为什么拥抱使用standard exceptions
  • 能否获得高度的code reuse是区分expert programmers和一般programmers的重要属性之一
  • Reusing standard exceptions能使你的API更容易learn, use, and read
  • fewer exception classes意味着smaller memory footprint 和 less time spent loading classes
  • 不要直接 reuse: Exception, RuntimeException, Throwable, or Error
  • 常被reused exceptions: IllegalArgumentException,IllegalStateException,NullPointerException,IndexOutOfBoundsException,ConcurrentModificationException,UnsupportedOperationException
  • 不要过度使用exception translation和exception chaining
  • 不要忽视异常,在try catch中,一个空的catch块破坏了exception的目的
对exception translation的理解
  • higher layers should catch lower-level exceptions and, in their place, throw exceptions that can be explained in terms of the higher-level abstraction
// Exception Translation
try {
    ... // Use lower-level abstraction to do our bidding
} catch (LowerLevelException e) {
    throw new HigherLevelException(...);
}
对exception chaining的理解
  • The lower-level exception (the cause) is passed to the higher-level exception
// Exception Chaining
try {
    ... // Use lower-level abstraction to do our bidding
} catch (LowerLevelException cause) {
    throw new HigherLevelException(cause);
}
// Exception with chaining-aware constructor
class HigherLevelException extends Exception {
    HigherLevelException(Throwable cause) {
        super(cause);
    }
}
说说对原子性失败(failure-atomic)的理解
  • 一次失败的方法调用应该使该对象处于调用之前的状态,具有这种属性的方法,称为failure-atomic
  • 使用failure atomicity时,不应该significantly 增加代码的cost和complexity
如何实现failure-atomic效果?
  • design immutable objects
  • 在修改对象状态之前,先计算并check parameters的正确性
  • 临时copy object,在copy object 计算完成,然后替换掉原来object的内容
  • 写recovery code,使该object的状态roll back到原始状态
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi阅读 7,312评论 0 10
  • 异常类(Exception Classes) Kotlin中所有的异常类都是Throwable的子类。每个异常都有...
    已迁至知乎_此不再维护阅读 3,834评论 0 0
  • 世间若是没有薄情之人,何来寡义之阂? 世间若是一篇和睦之象,何来死活之争? 似乎我像是深忧天下的骚客,揣着一肚子的...
    夙音阅读 258评论 1 1
  • 雨后的天空明镜似的,空气中还带着丝丝甜味。下班时间,街上人来人往,奔向各自目的地。其中有一位姑娘显的特别引人...
    晓卉669阅读 205评论 0 0
  • 我不喜欢你非让我理解是不是有点强人所难。
    酸奶两个阅读 142评论 0 0