异常,断言和日志

异常,断言和日志

处理错误

  • 如果出现错误造成操作未完成,程序应该:
  1. 返回一种安全状态,并能够让用户执行一些其他命令
  2. 允许用户保存所有结果,并以妥善方式终止程序
  • 可能出现的错误种类:
  1. 用户输入错误
  2. 设备错误
  3. 物理限制
  4. 代码错误
  • 异常分类:所有异常都继承与Throwable类的一个实例
  1. Throwable
  2. Error:Java运行时的异常,应用程序不应该抛出该错误
  3. Exception:关注点
  4. IOException:由IO错误等导致的异常

试图在文件尾部后面读取数据,试图打开一个不存在的文件,试图根据指定字符串查找Class对象,而这个字符串表示的类并不存在

  1. RuntimeException:由程序错误导致的异常

错误类型转换, 数组访问越界, 访问Null指针

如果出现RuntimeException那么一定是你的问题

  • 声明受查异常
  1. 调用一个抛出受查异常的方法
  2. 程序运行时发现错误,并利用throw语句抛出一个受查异常
  3. 程序出现错误
  4. Java虚拟机和运行时库出现的内部错误

不需要声明Java的内部错误,即Error对象及继承,以及RuntimeException及继承

Error不可控,RuntimeException应该避免

如果在子类中覆盖超类的方法,则子类的受查异常不应该比超类更通用

  • 如何抛出异常
  • 创建异常类

捕获异常

  • 捕获异常 try catch
  • 捕获多个异常
  • 再次抛出异常与异常链
try {
    //...
}
catch(SQLException e) {
    Throwable se = new ServletException("database error");
    se.initCause(e);
    throw se;
}
  • finally子句

在finally子句中释放资源

  • 带资源的finally子语句
try(Scanner in = new Scanner(new FileInputStream("/usr/share/dic/words"), "UTF-8"); 
    PrinterWriter out = new PrintWriter("out.txt"))
{
    while(in.hasNext())
        out.println(in.next().toUppperCase())    ;
}

资源支持Closeable接口,close的异常将在getSuppressed获取

  • 分析堆栈轨迹元素

使用异常机制的技巧

  1. 异常处理不能代替简单的测试
  2. 不要过分的细化异常
  3. 利用异常的层次结构
  4. 不要压制异常
  5. 在检测错误时,"苛刻"要比放任更好
  6. 不要羞于传递异常

使用断言

  • 断言的概念

assert 条件;

    assert x>0;
    assert x>0:x;
  • 启用禁用断言
  • 使用断言完成参数检查

断言只使用于开发和测试中

  • 为文档假设使用断言

记录日志

应用开发建议使用log4j,slf4j等

  1. 记录器: Logger log = Logger.getLogger(this.class);
  2. 日志管理器配置
  3. 本地化
  4. 处理器
  5. 过滤器
  6. 格式化器

调试技巧

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

推荐阅读更多精彩内容