- 注册时间
- 2011-3-22
- 最后登录
- 2013-6-27
- 在线时间
- 11644 小时
- 阅读权限
- 150
- 积分
- 62779
- 帖子
- 28923
- 精华
- 1
- UID
- 6
|
改写后的代码
根据上面的讨论,下面给出改写后的代码。也许有人会说它稍微有点?嗦,但是它有了比较完备的异常处理机制。- OutputStreamWriter out = "......."
- java.sql.Connection conn = "......"
- try {
- Statement stat = conn.createStatement();
- ResultSet rs = stat.executeQuery(
- "select uid, name from user");
- while (rs.next())
- {
- out.println("ID:" + rs.getString("uid") + ",姓名: " + rs.getString("name"));
- }
- }
- catch(SQLException sqlex)
- {
- out.println("警告:数据不完整");
- throw new ApplicationException("读取数据时出现SQL错误", sqlex);
- }
- catch(IOException ioex)
- {
- throw new ApplicationException("写入数据时出现IO错误", ioex);
- }
- finally
- {
- if (conn != null)
- {
- try {
- conn.close();
- }
- catch(SQLException sqlex2)
- {
- System.err(this.getClass().getName() + ".mymethod - 不能关闭数据库连接: " + sqlex2.toString());
- }
- }
-
- if (out != null) {
- try {
- out.close();
- }
- catch(IOException ioex2) 2 [+ ?( x+ E5 b3 Q3 J' [/ t4 ]+ c
- {
- System.err(this.getClass().getName() + ".mymethod - 不能关闭输出文件" + ioex2.toString());
- }
- }
- }
复制代码 本文的结论不是放之四海皆准的教条,有时常识和经验才是最好的老师。如果你对自己的做法没有百分之百的信心,务必加上详细、全面的注释。
另一方面,不要笑话这些错误,不妨问问你自己是否真地彻底摆脱了这些坏习惯。即使最有经验的程序员偶尔也会误入歧途,原因很简单,因为它们确确实实带来了“方便”。所有这些反例都可以看作Java编程世界的恶魔,它们美丽动人,无孔不入,时刻诱惑着你。也许有人会认为这些都属于鸡皮蒜毛的小事,不足挂齿,但请记住:勿以恶小而为之,勿以善小而不为。 |
|