- 在线时间
- 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>
" C; K2 u, s5 {% F0 t1 m<CENTER><CCID_NOBR>
% g, o1 E8 n- s3 Z* o& d<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>7 x: w3 d4 c* ?3 {: R3 R( G
7 m$ D( ^/ N3 ?- L
<TR>+ n1 R3 h+ ` b3 Z* b$ S
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...2 Z3 n. F% n8 b, s
java.sql.Connection conn = ...% | i" M3 L& ]7 [3 D, k
try {
! P4 M$ v' W; R) `2 g Statement stat =
5 e: |4 Z' x ]conn.createStatement();# F5 S3 |: f9 I& g6 `. Z! y
ResultSet rs = stat.executeQuery. @/ _1 [$ @# L' }' s# c8 ?
("select uid, name from user");
% n6 D% P) V# n6 O while (rs.next())1 h% o, b4 ^, `
{+ x8 }1 t( C1 _+ [7 C
out.println("ID:" + % ?% S* w( R! V3 G7 v
rs.getString("uid") + ",姓名: "* i/ V$ S6 I9 S6 v
+ rs.getString("name"));
5 r( I" u6 K; Z% M6 `; q {9 p }
/ {9 S: j( O& O$ j; a! @4 | }% N. A$ u& B$ \
catch(SQLException sqlex)
# |, j0 V/ O% X3 H- h4 P) n {
; `+ A5 Z: y1 m& t/ y' N out.println("警告:数据不完整");! E, {; n0 B" V# ^
throw new ApplicationException
" p. @) E7 h7 L("读取数据时出现SQL错误", sqlex);
! O/ W# r( k# B8 M; h' j9 d }0 m, K& n# g B5 e/ A
catch(IOException ioex)
: G( O$ h$ p" M& {$ Z$ e% @5 D {0 r& Z, w q5 V* x
throw new ApplicationException! T( { w7 w( K, b& r
("写入数据时出现IO错误", ioex);& e8 k: {3 E/ u# Y$ {" ?
}
1 t( ?9 O* c0 R finally
( ^' N! y2 @; S0 h* H H {
* T$ l) y0 @$ {; g. [3 f5 V2 [ if (conn != null) {
, d% d6 M1 s8 g( E$ t. _5 f try {# f6 h& j( b4 n$ a) C Y/ Z7 T" K
conn.close();
! v' h. Y8 l Z8 V }$ s; F; d" Y4 i0 l% f
catch(SQLException sqlex2)) O) j3 \7 K4 e l/ U) D
{8 m9 j/ ~7 `1 |% Q- Z
System.err(this.getClass().
" t7 c# ^) v& G8 D& QgetName() + ".mymethod - 不能关闭数据库连接:
8 X4 C0 ~6 @) A0 Z# Q' V4 _/ _" + sqlex2.toString());) h5 f/ i( x$ A( P8 y
}* Y$ U6 P' i0 {; ^0 V% \
}
+ L) i' a0 @9 [$ @ if (out != null)
$ O: h1 ]; S5 U' E1 A; c9 v3 e{
$ D9 w# f6 t, j9 ^! C( [7 h try {8 Z. Y/ B/ F0 G* K, i) a2 ]3 C
out.close();
1 S; y& _3 ^2 c. `) X, H h5 X, X f }) a& e" G$ B# R! L: [$ Y+ l
catch(IOException ioex2)# ^% L3 q3 w' a6 {4 x+ _
{9 W: w6 U9 \, l/ |4 N$ N" ~+ X" O
System.err(this.getClass().# o6 P4 K7 x, x. o
getName() + ".mymethod - 3 ?' m' L9 ~! _' G6 Z0 Y4 t
不能关闭输出文件" + ioex2.toString());
0 y* Z" [+ D+ x/ a& I }. R" H# `6 _! A) O& I- Y
}5 \% a2 n1 N, {% @. Y% o
}</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
|