- 在线时间
- 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>" i3 `: v9 M) U) v/ p6 H
<CENTER><CCID_NOBR>$ Y$ R S9 \( l, _
<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>0 H' b5 N* }7 {# v) v" }0 t/ Y
8 @1 A) O* G/ \% b2 L<TR>5 r N5 w- l) ]! b7 _) w
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...7 @3 L. ]/ l; O+ L6 N5 x
java.sql.Connection conn = ..." v) G& [8 z/ a* k. q, d" c3 N
try {
( k3 q" z2 R" I( w3 P! v Statement stat =
/ u# }6 D" H2 p2 Q8 m& I; ?4 ]! z% n/ sconn.createStatement();
/ o* t7 p1 f/ d. S9 r ResultSet rs = stat.executeQuery/ j1 h* Y7 N2 @$ v
("select uid, name from user");
+ r' J( B( V9 g$ r" U while (rs.next())
) m5 A( g* S7 C' l1 m {/ R" A0 }5 C- ~! h
out.println("ID:" +
8 F" h+ S! m, g/ j5 s- `) B. \rs.getString("uid") + ",姓名: "
0 p. Z' Q+ b# E, E+ rs.getString("name"));
6 P W( ^, C; x }
s0 f. A8 k" D }" W# S! i( S: ^1 R- t5 @# E* {
catch(SQLException sqlex)
4 k* M; z/ K( G5 e! H {+ g9 k) }/ ~6 n/ |- W
out.println("警告:数据不完整");! {- Q' a& X( F; t q* X- a# H
throw new ApplicationException
- [$ W! u5 I% s! t("读取数据时出现SQL错误", sqlex);
* c2 u& t; H8 ^* ^ }% Q& _ H1 i& U8 E3 k+ ?
catch(IOException ioex)
5 b$ m4 d$ r: L4 G4 r1 t4 L) I3 b2 x {9 m- P3 ^' X, x' i
throw new ApplicationException3 C1 }8 q( d1 }, \
("写入数据时出现IO错误", ioex);& Z0 O$ w' B8 \ \- M G: i
}% ?: I+ @1 U- `! } f
finally' F: [2 q1 r2 P" h8 C/ E/ O$ f
{
1 K6 h5 t5 O% @$ e: G4 z; W if (conn != null) {! x. [( i1 q# ` A2 d) y
try {$ U$ G8 G, E2 {, {, W5 Q
conn.close();5 ^! a" R1 [3 s5 @
}
6 u" \, o, h+ a) F1 f catch(SQLException sqlex2) ^" ~- f6 u3 U0 P- q) m
{/ D5 W$ h6 t- ]
System.err(this.getClass().
( G- X0 _# T/ i) d# K! ZgetName() + ".mymethod - 不能关闭数据库连接:( c" e$ k; i. j1 K+ ~
" + sqlex2.toString());7 E0 V: v% q! P0 v a/ O$ i
}
3 ?6 ~0 h2 X* R8 K( r& A }
8 I+ {1 T0 n( Y3 B% ` if (out != null), T4 b2 @# X9 ^1 U8 N5 u' U
{1 B+ W. {2 k3 t& _+ M2 s# j; c) K
try {' _# {, y7 N3 W+ q- M" |
out.close();
1 ?$ F; g) `2 p% K }0 I3 f: I! u8 ^3 j$ o
catch(IOException ioex2)& g4 R |" {4 a X( m0 \& i
{
1 R5 O" C! O4 X5 v; X1 n System.err(this.getClass().
1 [6 A/ h! c# o# f$ d/ V. ~getName() + ".mymethod -
- }% S& D4 \$ l# Q- W5 D不能关闭输出文件" + ioex2.toString());
7 @6 x ~9 a& n }
+ f- O, l7 V" K' F8 J }& B2 f4 C" |# f& m. ^; ?( |! k
}</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
|