- 在线时间
- 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 H" v1 {& }: R# c" }
<CENTER><CCID_NOBR>
) z; C; m6 T, R* k<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>+ t% m% K2 }1 \. w* l
: ?8 l. C" ]5 d( ~- K0 J
<TR> h% D" n; {9 ^9 N/ P( u4 Q
<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...
7 R8 N. H; u. B java.sql.Connection conn = ...
1 s" R, F3 \ J try {
) \! \8 f9 R0 h. x0 U4 j Statement stat = 7 W( R; v# C% i
conn.createStatement();
3 H3 \6 d- m% [# r# K0 D% c' D ResultSet rs = stat.executeQuery! V; H5 s4 f& V/ R( m1 }
("select uid, name from user");) t# m/ v( t9 b6 o: S* R
while (rs.next())/ b1 E3 i( }" f- }) l3 ^# Z: {) Q
{/ |- q% D! j" w: F+ q9 _
out.println("ID:" + 7 C3 r4 r d" ^
rs.getString("uid") + ",姓名: "" t5 `2 l0 U/ X% k
+ rs.getString("name"));( c: X c0 q+ g! f" ^
}
- J0 B2 H8 n* f+ d3 v. y4 M6 z8 A: } }
4 I+ g1 S4 G9 m. U/ K6 E9 U catch(SQLException sqlex)6 l- E& N% E- M1 n
{
" p. J G' R1 U5 l6 _ out.println("警告:数据不完整");
# q8 f" |! O; } throw new ApplicationException
# h! p7 H6 D' S6 u("读取数据时出现SQL错误", sqlex);& ]4 C, t( K9 n* T1 X
}
( f) I5 O- _+ n- x catch(IOException ioex)
8 o$ b5 k% S) O7 @* o }) E( R/ G {
8 u u3 c" U. v' K' v* ` throw new ApplicationException
1 P3 r$ q$ A6 Z7 a("写入数据时出现IO错误", ioex);1 e# q+ X0 w; F6 c
}
$ N$ `7 N1 }0 c7 b+ \ finally5 F% y7 w8 u2 S# l! s/ @
{, r6 ^8 x/ `* Z
if (conn != null) {
' V8 R _6 W- d- E6 d try {
2 K) O$ u6 B" e8 y; |! o/ p! ? conn.close();
/ O% b$ R( ?. b; M) K6 l }
! {4 B0 ^- b$ S5 b2 d1 c catch(SQLException sqlex2)% k7 I% s1 a3 Q+ ^, {# [
{
5 h9 m: ~% @+ Y- x* h. @ System.err(this.getClass()." A9 C* h" j+ H% p
getName() + ".mymethod - 不能关闭数据库连接:
0 Y4 E* w* i2 f. @' x" + sqlex2.toString());
0 _& D; r/ {5 y8 q }
2 _* M' ?. g1 K. }4 b. Z }8 ~% x+ M0 M/ F6 G3 K$ g D
if (out != null)
) }' |' o8 b+ \* M{
4 S7 Q% T4 {. F4 ^7 r try {
0 u8 q. d3 `6 t3 j8 {8 q. ?5 z out.close();% x5 _$ \( a* r( l) h) F
}
7 Q: R* W* U2 |+ S' K- K9 f1 | catch(IOException ioex2)
( N y, M4 J0 @. C' P! L {+ U( S5 j% I9 x+ R7 b X& v! L+ i
System.err(this.getClass().
* s2 J; e8 W' e. j; v6 ], ^getName() + ".mymethod -
+ Y6 W6 [! j; |# x U不能关闭输出文件" + ioex2.toString());
; u$ ]0 U# S) J' ^" I }
2 m' W4 z7 ` e9 ` }: }$ r+ |" h$ X+ z# V3 a) D; L6 h+ Y6 f
}</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
|