- 在线时间
- 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>
4 e" g. K) h( g4 {<CENTER><CCID_NOBR>
) F' n7 \2 R, I" c T% S& G<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>
2 }& u( G+ @1 l7 G7 N+ r. X. q1 u( Y% O" C* j- k3 J
<TR>" v) T4 l3 w* g* F3 N: M
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = .... V& V7 o& v: t1 g, K& ]6 D, h
java.sql.Connection conn = ...: L z- |/ a5 M g' y1 `1 l/ v
try {
, R: k) N# x) D' l" q) J0 { Statement stat = U6 @/ Y! h$ e- s2 @% T$ M' k
conn.createStatement();
7 K8 n* v9 k8 J2 m7 u# Y9 S ResultSet rs = stat.executeQuery
3 O5 L2 s' ]9 }0 e! g }- N9 x* Y% W("select uid, name from user");) ~4 Q3 w; _! j7 z1 x" t/ @; V
while (rs.next())" T; h! Z" ~9 X' Z9 a
{6 t1 U4 U+ Y2 b5 d- P' K8 m
out.println("ID:" +
5 J+ h8 e+ B, a$ C2 Ars.getString("uid") + ",姓名: "
6 L% i# |. K X8 O+ rs.getString("name")); q4 l" O' |8 L4 E {
}: G. u6 h+ G5 `! F- W) F/ t }
}
' ]' [1 e1 c8 x2 j, H' E* y5 n& @ catch(SQLException sqlex)
! W8 s, l, e# g- G {
2 C8 I5 O6 ^" d) [ out.println("警告:数据不完整");
5 b. f/ R& V9 u3 _5 b throw new ApplicationException l' G4 S4 V+ M, {. l( g6 z
("读取数据时出现SQL错误", sqlex);" o, Q) o: U8 }$ e1 o" V
}: O; A1 |2 U1 H% A9 A
catch(IOException ioex)0 k4 l B2 ]9 ~5 v" @! O
{6 [* a# j' J$ ]9 Y% q
throw new ApplicationException
7 o2 {& }* m" l6 [("写入数据时出现IO错误", ioex);
; G) [$ [/ A& F% A }
. |* B# M' m$ v- b. j* _# i i) M- _ finally
+ m) \9 J% l) A! F {
+ F9 ~3 H1 `; \7 L8 x/ w if (conn != null) {/ ~, Z0 k8 N, a1 G. D8 ^
try {
* [+ {1 o# P2 Y) P- G& h3 w conn.close();
: }& P3 m7 {5 C }
$ m) {- \6 S8 \ catch(SQLException sqlex2)
V/ c- ^5 d1 O {( h% \% \/ o& a9 a* _1 O- w+ x
System.err(this.getClass().
6 B6 d0 o( r! b: t) _( _ ggetName() + ".mymethod - 不能关闭数据库连接:; ?5 X. a9 Y7 Z# I9 Q& w
" + sqlex2.toString());7 t3 M1 U4 g, `( e8 ~, ~
}
! b W4 q2 {, z2 x }
* S3 c+ W1 G5 k& @% A if (out != null)
; g: d9 o R6 P" e4 x3 H{, V( w( d+ \, r; P
try {
: {6 h/ r! p4 }6 k$ z: q5 } out.close();
5 k2 Y0 }, P! k3 h }
- L+ Q& j' @/ ~" x, H catch(IOException ioex2)
2 L: A) @1 T+ D. H3 T8 x {
3 n, V' V0 G X5 h/ w( e System.err(this.getClass().5 B; q: a1 O1 z% n6 R7 k' I
getName() + ".mymethod - 7 m4 ^( x8 k' S' x; i6 [& x: _
不能关闭输出文件" + ioex2.toString());( F/ c* p3 P$ w
}
) g% U8 A9 m3 M% n }
, a ~$ Q0 c2 `/ H& P3 x5 s }</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
|