- 在线时间
- 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> X* P/ D$ c5 i6 W+ X* L1 [+ b
<CENTER><CCID_NOBR>
f! y. o- _& E4 i<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>! A! k( _# z) P. Q- b! W F7 N( N
8 Q- Y! ]+ t. P9 a% q0 ]/ j
<TR>) X" {( T) x% f) C
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...
4 \+ n% D* N, q( O& q" C java.sql.Connection conn = ...9 _: [) P2 y L4 d2 I6 \' `
try {
) |3 d. d7 I, b# d! t; b Statement stat =
) L L: E. m( F! I3 mconn.createStatement();
g$ B7 Y8 F- o R ResultSet rs = stat.executeQuery% Y+ ?, i3 D/ O
("select uid, name from user");+ p4 Y) w* g/ B/ s6 k
while (rs.next())
; w+ Y E" U h, X. ~ {' q9 C0 e N" U2 [# ^& e
out.println("ID:" +
# X( a3 x0 K1 v8 s! ]& \4 V$ Qrs.getString("uid") + ",姓名: "! m' P: d6 a, B, J3 h
+ rs.getString("name"));7 i; W. @6 C) ~7 Y) R0 L
}! T/ j8 i" m" Z' S, [+ U& G
}+ t p+ M! W! h( E5 U: Y
catch(SQLException sqlex)
7 S/ q, @7 v4 A% i4 Q {
7 f) a3 b* k$ T% a8 [) a. W out.println("警告:数据不完整");
$ {( M0 \1 I9 L# @) w9 Z* v throw new ApplicationException
7 D5 X+ ^$ l \& S("读取数据时出现SQL错误", sqlex);# ^; u, }/ A* o
}# Z1 [. R" @5 Q( r/ T ^' k6 Y: B
catch(IOException ioex): b! ^) ~# L+ B) i0 S
{
9 f. r I# B) E; w6 G& k* o; v throw new ApplicationException
$ f% ]* w& v9 D' J* b" ]9 c("写入数据时出现IO错误", ioex); w& p9 J# E9 @$ @8 i
}) d4 K+ f( H7 p( q& j& N3 n
finally
8 C+ H2 H9 w" r5 A {- P9 R7 I* i* G, K8 I- {3 v: Q% U
if (conn != null) {* R, L1 w" S$ q) i
try {
* C" S) u" w! z3 z conn.close();0 T1 W( y8 u& ?) h* \
}
6 O& \- Y6 L* P. M catch(SQLException sqlex2)
6 h D) L2 U M {. p+ {7 B" @, m1 N
System.err(this.getClass().5 B% L: N/ p' f* W) ^
getName() + ".mymethod - 不能关闭数据库连接:$ B( ~. B' G! D0 i
" + sqlex2.toString());$ x! Y' d7 x/ m1 X4 u
}: v+ @& Z S. s: k
}; \4 D- y/ y4 y# ]% l2 T0 }
if (out != null)
, y0 h$ {# ]+ y! H* I3 ]6 Z{8 q1 V0 V. ~* H# A2 S! V
try {8 k) t: ^0 M' z% S) |, A e
out.close();: y; W" [- o$ M6 O& d
}
S9 `( h* M3 |( R6 _ catch(IOException ioex2)9 W. A6 V" E d* N* E
{" h) [( s$ t, }% g# o# R8 m' r1 |; U9 ?
System.err(this.getClass().
$ N7 L, f, c! Q% YgetName() + ".mymethod -
+ y: Q, R% ?3 q3 z& M: W5 N不能关闭输出文件" + ioex2.toString());
! g7 P; Q" {# D }
+ P* X' j0 i0 ?6 ^# p8 I3 _ }' O, K& B6 Z9 |' X3 w1 y
}</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
|