- 在线时间
- 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>( b7 }; G) W- E! J; V1 D' x7 `! n
<CENTER><CCID_NOBR>+ a( }' y5 l/ I3 u9 h
<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>
5 d4 T$ h+ E9 F+ I. S6 N) M" J
6 B! d( i7 E& m# }$ N9 }<TR>
9 Y$ {( b5 } ?; q- X: j7 j( f& y<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...
t; V3 I2 f, z java.sql.Connection conn = ...
( u% _! T! o4 a9 s try {
- F- u5 y# U: z. I$ p Statement stat = * L! C9 `' V6 f8 L9 j4 O
conn.createStatement();
; |$ q& L% C g; q9 z6 Z; K5 m- m ResultSet rs = stat.executeQuery
% u$ r- Z. Y& G6 V7 ^# N("select uid, name from user");
9 e, C% R9 J4 V) l5 G while (rs.next())
& O/ N5 h2 G3 L {- G! ]6 }; b8 z. p" ?* E
out.println("ID:" + ! W' D; J7 m. g) R1 [4 i7 O3 E- p4 m
rs.getString("uid") + ",姓名: "7 @; j+ `9 `8 l1 i. |9 n7 Y' a
+ rs.getString("name"));! l+ @: O" y% Y5 s _( H; u; |
}# w! i p3 C3 x$ D7 e
}
& y( j" A' X+ d1 Z" r k catch(SQLException sqlex)
3 E5 B: o9 K j0 {6 T! W {5 S$ K9 h0 Q' X& @
out.println("警告:数据不完整");4 C5 q. R. q& E3 [ F! ?
throw new ApplicationException) q8 L9 a8 \; Q9 }
("读取数据时出现SQL错误", sqlex);
5 A3 T1 _- O2 r) I K8 V }$ k; a, ~, c R- G3 w F
catch(IOException ioex): K. \3 B, C% ~, b
{
& ?% ?$ J6 y8 n' ^- O- n throw new ApplicationException6 R0 ~8 `' w2 G9 j
("写入数据时出现IO错误", ioex);
3 F. e4 }/ p0 j! t }1 [' [* [2 z6 v5 |/ |2 v
finally
n9 }! M9 q* X: H$ @5 C& H6 k {
. X$ G1 p( D [$ t# E) t if (conn != null) {
% l/ {+ H! K- X! S8 Q% }. e4 u try {
! Y' E9 X! b- l6 c3 a$ m+ i# x conn.close();
5 ~/ ?% X* X+ s: L4 K" W1 K }
5 D5 J4 K+ U: h# ~" C( Z+ X catch(SQLException sqlex2)
F3 ]. a/ e4 _, s0 X+ w1 j3 ] {# h3 f7 y; q' p4 y( p6 m
System.err(this.getClass().
6 X' L% k9 G6 s" @* EgetName() + ".mymethod - 不能关闭数据库连接:
: w& e) @! B4 H7 Z/ E" S" + sqlex2.toString());
8 v, y1 j$ {: f8 Y, F0 \- A& c }
3 U8 `7 E" q3 F }
' p& s' p) N7 y0 s( h) s if (out != null)' z( Y/ ?1 N0 r2 L6 R/ {
{
% c7 X( `# a5 K/ L- V! ~ try {
9 z7 J& k5 ~# s out.close();) C: \2 j1 J( K
}+ @4 a! n' V: U# P# ?
catch(IOException ioex2)2 l- o6 v: z+ I5 @8 y H4 u' ~
{
' P' a3 }1 F" Z7 d4 N$ C/ v8 ^ System.err(this.getClass().6 o5 J7 j1 m& F7 n1 q# f. m
getName() + ".mymethod -
4 T1 K3 V. \0 M, Y不能关闭输出文件" + ioex2.toString());2 M) w, b) D$ |8 C4 ~* q
}
' z. ?+ F; ?! a3 b }
9 U1 N/ l2 i0 p% W3 l1 f }</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
|