- 在线时间
- 0 小时
- 最后登录
- 2007-11-17
- 注册时间
- 2005-1-15
- 听众数
- 2
- 收听数
- 0
- 能力
- 0 分
- 体力
- 1102 点
- 威望
- 0 点
- 阅读权限
- 40
- 积分
- 400
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 132
- 主题
- 85
- 精华
- 0
- 分享
- 0
- 好友
- 0
升级   33.33% 该用户从未签到
 |
反例之六:输出数据不完整 <BR><BR>代码:7行-11行。 <BR><BR>不完整的数据是Java程序的隐形杀手。仔细观察这段代码,考虑一下如果循环的中间抛出了异常,会发生什么事情。循环的执行当然是要被打断的,其次,catch块会执行??就这些,再也没有其他动作了。 <BR><BR>已经输出的数据怎么办?使用这些数据的人或设备将收到一份不完整的(因而也是错误的)数据,却得不到任何有关这份数据是否完整的提示。对于有些系统来说,数据不完整可能比系统停止运行带来更大的损失。 <BR><BR>较为理想的处置办法是向输出设备写一些信息,声明数据的不完整性;另一种可能有效的办法是,先缓冲要输出的数据,准备好全部数据之后再一次性输出。 <BR><BR>结论六:全面考虑可能出现的异常以及这些异常对执行流程的影响。 <BR><BR>改写后的代码 <BR><BR>根据上面的讨论,下面给出改写后的代码。也许有人会说它稍微有点?嗦,但是它有了比较完备的异常处理机制。 <BR><BR>
0 B. S$ @3 C" Q9 @<CENTER><CCID_NOBR>
& D; [& a: i, ^, Y8 M/ J<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>9 X6 I- t. p' K1 \
+ i6 t" C# G' M! ~( s2 T5 @
<TR>
, n9 R5 _8 S5 a, }<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...
' N( z" }6 m( O& T8 }" W* W java.sql.Connection conn = ...
* Z. c5 ]# u6 i' M: W8 g' H try {
% X, t3 h; a& D6 A Statement stat = * _: F/ Y% g/ G7 J
conn.createStatement();: h4 r' ?5 w7 @$ H
ResultSet rs = stat.executeQuery
2 d! S' E" W. {; D# ^0 P5 o("select uid, name from user");) M, H/ y4 B- {" w6 ?3 z/ j
while (rs.next())
' }! i# t7 R0 V7 C. | g {
9 c- @2 g A# h+ ]2 p, B out.println("ID:" +
( r& o7 J& w6 U' [" F4 a. b. O! C6 jrs.getString("uid") + ",姓名: "+ s1 l5 q' Q# H; _# ^! o6 s
+ rs.getString("name"));
) q" t$ Q8 v# p8 w2 T: E' ` }6 S8 ^& O% n& b3 G; P- q
}5 X; A& F5 _/ x: Y. m; F
catch(SQLException sqlex)7 ^" \% N, Q( }
{% A5 Y: t' Q f
out.println("警告:数据不完整");
7 ~) h+ @/ u1 i' a7 l/ g throw new ApplicationException+ O+ a$ p/ \: F5 K5 C( S$ u
("读取数据时出现SQL错误", sqlex);4 \0 G+ ~# V" H: g( ~8 q* B
}/ `$ u) @. a) \6 H d$ d
catch(IOException ioex)
7 A% H3 Z( D' Y! Q {8 C5 d: T; o8 z! i+ i5 i
throw new ApplicationException
* _2 }* m% A# u# J- a, {. D("写入数据时出现IO错误", ioex);
3 f6 d( r+ a* j6 R, | }
" s# s2 T7 D+ \# G4 {2 M finally
' L) P3 Q( h& b; K- N {9 g" ~: ^8 ?/ a
if (conn != null) {
) J3 [; G4 A/ `9 x* U+ Y" O try {
7 _* ^& m! @. C& i! \# }$ M conn.close();4 k1 c" w* t: k) ?; x& r3 c
}5 s x; N5 V) `9 X9 E, i( Z1 ~
catch(SQLException sqlex2)
% ], V0 m7 b, | {) g2 ^" Q1 y( O( `1 G
System.err(this.getClass().
, b. K( U0 R, |getName() + ".mymethod - 不能关闭数据库连接:
/ \& e3 p' m* }$ C. r" + sqlex2.toString());
8 ?. a1 Q7 h: t7 ?& M }
! R9 n8 R7 v* M, y# d# A& V }+ _: X/ i) a4 B9 R3 H. S6 l
if (out != null)
7 A, {# H: c/ q$ Q5 }4 X. j{( l3 V9 y; }) R9 K( X" t( c
try {
+ g- ~0 L' p. A/ O% S* b* G h out.close();
4 W8 e: O2 ]7 v! l' G' t! T3 A) L$ w }
" h9 M, t2 a- K. \3 [" a catch(IOException ioex2)
9 i3 Z1 l7 I9 {; J( m/ O {
) q) T4 h9 r" e: z/ x System.err(this.getClass().: S. ?8 K$ T! \9 D) e& l% ]
getName() + ".mymethod -
# q1 X- @" m7 I5 b不能关闭输出文件" + ioex2.toString());; F. K4 }* a; ~1 w7 M
}) k- u& m6 \) A6 p B; |$ A; F
}
& [ j+ {" t- w3 H }</CCID_CODE></PRE></TD></TR></TABLE></CCID_NOBR></CENTER><BR><BR>本文的结论不是放之四海皆准的教条,有时常识和经验才是最好的老师。如果你对自己的做法没有百分之百的信心,务必加上详细、全面的注释。 <BR><BR>一方面,不要笑话这些错误,不妨问问你自己是否真地彻底摆脱了这些坏习惯。即使最有经验的程序员偶尔也会误入歧途,原因很简单,因为它们确确实实带来了“方便”。所有这些反例都可以看作Java编程世界的恶魔,它们美丽动人,无孔不入,时刻诱惑着你。也许有人会认为这些都属于鸡皮蒜毛的小事,不足挂齿,但请记住:勿以恶小而为之,勿以善小而不为。 <BR><BR>转载自: <a href="http://www.itzero.net/Article/learner/2005_10/3385.html" target="_blank" >http://www.itzero.net/Article/learner/2005_10/3385.html</A><BR> |
zan
|