- 在线时间
- 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>
3 y" M( u) J% L7 a1 P% Z<CENTER><CCID_NOBR>
( r. H) m3 J+ Z3 t- }<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>7 _& W( |. a& U1 a5 A
6 b/ R- G0 m; u. f<TR>$ }0 N0 L+ u, Y1 Z: F x# k
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...4 L0 a) p9 M8 {! v; t/ G4 G( }/ k
java.sql.Connection conn = ...- V% t, K4 v3 O4 E5 T) l
try {
' u0 k2 m4 f5 S! g Statement stat =
8 z( {) V/ m# k7 ~- K: w" gconn.createStatement();
" [/ N/ y# `! `: n- \0 \ ResultSet rs = stat.executeQuery
3 ?2 S# I V( n("select uid, name from user");" C: {( f5 B0 }) m
while (rs.next())% R0 `- H {' x7 O
{- E" R% p- u7 @& W; L1 B X* i
out.println("ID:" +
6 N/ _) ^7 v5 ^& [, I8 `5 {3 V5 M% W# ~rs.getString("uid") + ",姓名: "
. e- H$ `3 y6 {8 o+ rs.getString("name"));- ^ u* i% n$ N; _
}3 \; A7 c" Z$ d; E7 ~+ |
}" o+ B' Q9 X* W7 f+ y+ L, ?
catch(SQLException sqlex)
9 m1 f# u i- p! ` {
" q5 Q3 G' V) W7 _5 j' v out.println("警告:数据不完整");4 q% d& L7 }( }: J& G6 w
throw new ApplicationException0 l7 K8 V' P; u+ O
("读取数据时出现SQL错误", sqlex);" f- D5 t+ J4 ~9 E! U: D, k
}, u b' Q* J- ~, e, X
catch(IOException ioex)
% q5 E V i9 h1 Z+ N% x) g {
2 W7 c$ t& {* W8 l j throw new ApplicationException
2 w0 w. b* I9 w! U1 j("写入数据时出现IO错误", ioex);
7 T; p: Q5 s5 d' G }
* d# r& d5 a+ ?: Q/ E$ e1 V finally
4 i% C1 e- J# } w5 v& j d9 w8 T" A {
2 {7 v" t* p( ~. S5 Y if (conn != null) {
* z. x$ v# X' f9 S try {7 S, N+ E+ F* L
conn.close();
) C- K& @/ n8 Y0 H+ j2 T+ f- Q1 s }
5 y9 x! N% w3 H# N3 V$ w+ W9 J3 e! l catch(SQLException sqlex2)$ M7 G9 Z6 Y* S3 u! ]" \
{
% b" v4 L5 Z8 s' l+ j% h! o3 _ System.err(this.getClass().$ ?, M+ P9 T V# g5 V
getName() + ".mymethod - 不能关闭数据库连接:
' f+ x( m) q" B5 [( |* W3 A" + sqlex2.toString());* d4 V I% `& s& F4 O/ p
}2 W1 v: @( L. u9 f
}& ~- r! L! }6 A+ U* P
if (out != null)8 Y6 v) a* h7 f
{
( |0 f3 h& g5 ]" C6 T* E try {
; E3 q: {/ x" R0 I5 h1 J4 L: a, y7 Z out.close();
/ b' U0 I5 A# V4 ?4 n! ?% d }
' D8 T+ g7 |. b4 }8 f8 Z catch(IOException ioex2)
( E1 H9 [% t; M4 R6 i6 [ {
) R) r# Q, T" k" l0 G6 e* l* Z/ q System.err(this.getClass().( p4 V( n" q) ^8 v1 j/ a
getName() + ".mymethod -
' c; @ g$ ]* V2 r, K$ U3 H' F不能关闭输出文件" + ioex2.toString());, c- o0 L3 l; w$ l! r9 r8 B7 B
}
7 {2 L, V/ X; l8 ` }
' U0 P/ U6 b: [9 s$ S) O' t }</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
|