- 在线时间
- 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>
" T4 F& Z+ h* x, b% k<CENTER><CCID_NOBR>6 Z2 X" U7 }8 S7 U( N
<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>4 ^( ~8 @: V, ]3 K1 [$ q
, O& Y% b1 q' \( u; }' _, k
<TR>, g0 {0 Q( C$ U" h6 w
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...3 C5 [/ c; H' }: H6 g9 k
java.sql.Connection conn = ...1 l' K6 k( l* b, W
try {
; S2 V& _4 a7 k+ B/ D: ~ Statement stat =
* w1 d. A) i4 u6 w- F+ hconn.createStatement();+ @, u4 `/ M. u
ResultSet rs = stat.executeQuery
7 ?6 t5 q$ y: R; e/ A5 W("select uid, name from user");
: ]1 C1 m! N, i9 t+ n+ o while (rs.next())% j* X1 l6 r9 b$ X/ a& Z. g& F$ p
{
; a2 u2 P) h0 ] k2 L out.println("ID:" +
' m( `) x& c6 ^, Frs.getString("uid") + ",姓名: "( [: Y$ A4 O" e6 p6 s" b; ^( I
+ rs.getString("name"));
; D. {5 B) {- Z9 B5 q/ G# } }
% M4 Z7 [% H; O. e2 r }# O* U B j# e4 J
catch(SQLException sqlex)0 P7 ] H% R1 \' n. ]
{' J5 r' n8 z; r# K
out.println("警告:数据不完整");
6 L2 ]; ?/ p$ A! X7 ]: G throw new ApplicationException
; e7 C; `! ?: ?' j("读取数据时出现SQL错误", sqlex);, g) R/ q/ k8 Z4 P& k, O6 ]: m c, _7 t
}# O+ ]4 N% @/ U( n8 x. e
catch(IOException ioex)+ a- x8 d! `5 z- a
{7 r7 e3 Y) x/ B4 M
throw new ApplicationException3 C7 ]" l o0 j d& U
("写入数据时出现IO错误", ioex);
# H2 n5 i, ^+ {8 C: {( l }0 F) ]6 ~ c& }: s+ d
finally
3 E' k3 T. Q/ j( L! [ {9 ]$ \+ J. `% K7 k& C+ g
if (conn != null) {
2 c$ @/ M7 J! P7 ?: v4 U o try {
# z2 G5 e9 } ^0 k* C* z conn.close();/ Q a. G6 \1 Q' G
}0 k" \1 B9 J: U2 B. J
catch(SQLException sqlex2)
' r1 T# S1 L# ~ {& L4 }* {8 A5 z5 G; L0 L; w$ m8 v
System.err(this.getClass().' j6 B' ^/ q) D" ?' U+ s$ U
getName() + ".mymethod - 不能关闭数据库连接:) [ G8 {: j& K
" + sqlex2.toString());" B1 q) U: }* D5 G4 }
}( a& u. Q5 S7 N+ ^
}
; s4 m$ g7 y, E4 |# a+ k if (out != null)
4 w6 V( L' l: i0 I{
2 w* B/ f7 n% K/ K* W) ~( E try {1 z1 U7 f! b- o8 z& b
out.close();
5 r, J9 c3 }% A. ^1 T# A2 b& c }; w. c# p" F2 g8 K4 u8 I, E0 z
catch(IOException ioex2)
3 V6 \4 D$ j% G. x* a {
( o7 k9 Z' o! N. x: c- d! E System.err(this.getClass().& _! Z* ]5 o O* e) ?! s' [+ i$ X- p/ b
getName() + ".mymethod -
" d Q0 j6 z- t不能关闭输出文件" + ioex2.toString());( k* k7 C) ]( z8 N/ ?
}" r0 P5 x( X; Y, t& h6 O
}
; r# x* |- d! ^0 Y1 T) G& R }</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
|