- 在线时间
- 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>
: N* D& |$ D5 ~+ \; r r( H<CENTER><CCID_NOBR>
% o: X" Z# r/ Z; ], y& p7 s) u9 _<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1># [( `9 N. T4 Z8 _0 c) X) ?6 A
& ~- j/ L, I1 W0 v( S) g
<TR>! O7 S/ X( D* H" k( [% o, e
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...* t# L1 R- K+ w( Y; O4 @! q
java.sql.Connection conn = ...( v9 R" C4 s4 e9 ~
try {% q# P1 L* V4 _, K1 P( F+ P7 r
Statement stat = 5 @. f7 n; F" y) S& _; }
conn.createStatement();
- k o- `& C6 V" d' H) i7 ]$ P ResultSet rs = stat.executeQuery
' ?2 f x! |9 B/ u) h8 |, C("select uid, name from user");; u( I* D# j3 ~2 d
while (rs.next())' `7 M: t) I1 s2 d0 s7 y
{( Z3 n& {# k1 }7 ~( H0 s
out.println("ID:" +
& s- J# l9 C3 \! frs.getString("uid") + ",姓名: "& x7 J8 h1 g6 } Q% T0 z2 x5 v
+ rs.getString("name"));/ `" U+ D0 n5 z7 y+ t! P
}
+ s' ^ ?. q; [+ b. j$ f$ R }
; e0 D0 T8 X; q5 C. U' B2 m8 J catch(SQLException sqlex)
% h; n2 t! X. | {
3 O5 }4 n0 j- O, O5 N1 j out.println("警告:数据不完整");1 Q+ g, [4 u; V" C8 N- B# c
throw new ApplicationException
! U/ { R; K$ n1 P t("读取数据时出现SQL错误", sqlex);
$ R$ _! ]0 Y2 I! |! b! a }
# s* T0 J4 c% i9 e4 o3 ] catch(IOException ioex)
( g0 I& N. D' r0 t c e {
2 _/ G7 ^1 d; | throw new ApplicationException
; b% p$ U! z$ }$ z& i$ M' a("写入数据时出现IO错误", ioex);
( u! H0 o! f! X4 c) @ }
7 G$ h4 Y6 H# J finally. I2 t2 o! A9 P" a( T
{# a; D0 @+ M2 a7 C3 m- @+ E* j
if (conn != null) {; B0 b& R9 \% V. O8 U# ~
try {
. D: B1 z2 C! ]8 f) L9 f conn.close();
, Z& U9 `4 S' v2 `- M" S) Q5 A }7 M: f0 w N% F1 Q( H# p) [
catch(SQLException sqlex2)
a, w" c3 I9 C- o4 h$ | {
( w. S! h2 m' w# ~0 u$ U- C2 T! ?( a System.err(this.getClass(). }/ F8 y3 q! A+ k- n' }7 N
getName() + ".mymethod - 不能关闭数据库连接:8 k0 v$ t6 b4 `3 f% Z. K( B8 j
" + sqlex2.toString()); G. ?+ G/ _9 i' u2 h
}% ]. o" j) p, V4 ]3 t1 k! d
}+ K) D' i0 y7 v/ C) l$ L
if (out != null)
% C' F4 h$ M, f8 Z: b, _) f7 `{
4 a8 {. Z' C9 P$ _3 v try {! n- [9 \# \- r: ~2 P$ j' N! `/ D
out.close();
( A( ^ R3 ^: h5 E7 x }+ H) G' O Z* I1 H/ x# Y
catch(IOException ioex2): z7 i' F \/ g+ [, ^( K
{
9 c5 x# r% I7 D( G& j System.err(this.getClass().( B% ?% F3 k$ B2 {, b
getName() + ".mymethod - : j$ U! ^# q5 ^4 ^0 l
不能关闭输出文件" + ioex2.toString());' L! g j7 e. T' Y+ `1 D0 N
}* y& I/ j) i' Q% P$ z3 k! b
}% g& Y; c. m& Y2 z8 D
}</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
|