- 在线时间
- 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>
9 i# l2 }6 e9 Z# C9 L- d5 U<CENTER><CCID_NOBR>
! u1 Y: v, b, J/ E0 p/ R7 l- r; o- S<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>
0 c% q+ Y8 F3 G W8 B, `$ D( L% s$ O* R0 S
<TR>3 F9 E- G; z# a
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ... e4 U6 B! ?$ X' J, a* n
java.sql.Connection conn = ...
" S- V! V- K, Y4 B/ o try {
# t8 d) L1 R8 @ v9 y Statement stat = ( {- p- z, N, b b
conn.createStatement();3 h* z L5 Y5 N" s
ResultSet rs = stat.executeQuery
5 F: l& F2 V! O2 Y, ]("select uid, name from user");
/ D; a5 _1 r# Z6 G& R# x: [ while (rs.next())
2 e5 w/ v2 C' T3 m5 e3 S' _ {
: f. V: b" w! B0 O& y. K7 w# Z out.println("ID:" + ; s, P9 Q; y2 L1 B
rs.getString("uid") + ",姓名: ") t& W) [( o5 I8 J4 p! C1 G' I
+ rs.getString("name"));
- Q3 s) C% X1 A7 k! C% ^ }. j2 n9 d9 d8 E: R7 z$ j( V5 ~2 }
}+ u/ C; S1 [+ Q. |0 E" D0 X
catch(SQLException sqlex)
0 S( c8 h3 X( H5 p, u4 A {) M- W$ X; n0 B# X3 Q: s
out.println("警告:数据不完整");: P! _8 K% i9 C1 E
throw new ApplicationException
( R1 F$ F: F6 w% @. }: s("读取数据时出现SQL错误", sqlex);
! G$ o7 y2 W P j2 C g4 x }; z, D% ]2 s2 k
catch(IOException ioex)% Q5 Y1 W0 F0 Y# W/ f
{. R( L/ M( u4 l
throw new ApplicationException
+ ~- J4 q$ J) d H q& }$ y! p0 A("写入数据时出现IO错误", ioex);
+ @4 E% m K- \2 Z. K3 X }6 {' X, T" \. O% v- y
finally
) o+ f1 Q( T- T1 v {5 l' a* w3 r" i& O7 h7 }( r
if (conn != null) {
3 ]$ V1 f( `4 s) A" P try {5 P& Z- ~" e, O- f ~
conn.close();; r+ Z# t5 M% q% s$ C- p
}
# D* ~+ {, x, S catch(SQLException sqlex2)* p) y5 T$ y% y! [3 Q( e, ?
{; w( e0 Q5 _; j! K5 \
System.err(this.getClass().
+ w" \+ i- t7 a4 v( l# m7 o/ pgetName() + ".mymethod - 不能关闭数据库连接:
" I* h* X3 `2 K& W8 H7 K% P, ~" + sqlex2.toString());, G) A$ x8 C0 X+ r3 I3 f
}
) q0 m) x, |) X0 F8 B }
0 h9 q! N& @- L$ l* M I& A if (out != null)0 _5 G1 `1 i; E9 U, C
{3 A5 p8 j s* I0 c9 D& S( r
try {
6 \( h# k. f& X. m# t/ J0 ^/ W out.close();
. b- ?1 o' X" G$ P {" P }2 ~ K' l; ?5 R' J1 o- }) @
catch(IOException ioex2)
( E" G$ L7 e) E- T# m {* ~: t+ F/ z1 L8 c; W
System.err(this.getClass().
5 D/ O6 ]/ y( P$ BgetName() + ".mymethod - 7 K J& X4 F0 s5 U/ L) O1 ]
不能关闭输出文件" + ioex2.toString());0 s9 R. ?2 r0 ?3 s& V' l c
}
5 Z2 ^' B8 c$ a, T% W" U$ [ }
; V/ ]1 U% K( b" z; Y& T5 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
|