- 在线时间
- 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>
- Y2 b+ ^, S& v: U3 ~. `* _; a8 q<CENTER><CCID_NOBR>
. [# n6 L# I+ C( M( L/ j- m! E. H; U<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>1 E2 y1 _9 K3 p7 b
' K7 I9 \. @: D2 b5 N9 g
<TR>
" U9 H) h9 {& s<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...& n. M$ C: I4 ]3 O, c9 x; J
java.sql.Connection conn = ...# J* F( s( y/ D% \# Q0 P7 t4 S
try {/ @* u3 s, G# ?8 \
Statement stat =
$ k& m8 I6 c* Q1 [$ oconn.createStatement();
7 W* C( a6 K+ r5 e& V; u' h6 A0 ^ ResultSet rs = stat.executeQuery3 Q! M+ W) w0 v; c5 q
("select uid, name from user");
6 ^( V) `' r8 G0 r% ^) d while (rs.next()); \8 m* j z9 m/ {# L0 E" N
{
T( N4 Y r1 ~3 X; c% W out.println("ID:" +
" o' T# N t: ~7 o& C' grs.getString("uid") + ",姓名: "
A1 \7 Q9 J: i$ t8 T8 ]+ rs.getString("name"));
& X& f( G" b; a6 V/ Q+ b5 A }2 k# B1 D4 d4 s5 p" q$ K% S' A
}
- [4 Z% H; U8 d& p) V; m catch(SQLException sqlex) m; @/ M. X! v
{4 U, ^$ A s; G! |, t. {5 [
out.println("警告:数据不完整");
4 z4 ?: V8 ~) b, L% e2 Z* x throw new ApplicationException1 |2 c8 i. v8 C$ R" R
("读取数据时出现SQL错误", sqlex);
0 h. K4 }, M1 ^ }7 Y) v' I, {3 G# R# S' D
catch(IOException ioex)
! t, w, n! W6 U3 w {
: ]- h* E0 P6 _ throw new ApplicationException
* p0 `$ r( |0 y. j, k6 `("写入数据时出现IO错误", ioex);, L9 ^4 I: a# d+ e+ t6 U% c+ l
}
1 K0 x5 ?2 D4 b' P finally
( T4 p" z# L" N, n/ _ {8 T" V" b8 f! _2 E$ R) |, u' ?/ S
if (conn != null) {$ ]5 F) B5 R2 W7 U4 g( u: T
try {' ~! _- @2 e+ f3 K4 n) U3 \
conn.close();$ `6 q* f0 W/ Q3 [& d& k
}9 Q. z& O) @0 c. [ n: G; q
catch(SQLException sqlex2)# p& V! m/ F2 p2 R+ _) j! m; a
{* J4 W5 B3 t9 b" ~, `
System.err(this.getClass().
# S% B3 G5 _, LgetName() + ".mymethod - 不能关闭数据库连接:
* u! L w. P5 k D" + sqlex2.toString());4 b+ H2 A0 f# J- B
}
3 w9 k3 J; N) x7 m4 ?! I4 y }8 U0 j7 ^+ V' {! m" J* w
if (out != null)- r1 A S2 z ?5 F/ W+ P1 J+ X
{' ^: F3 X. W3 I' e3 A8 E
try {. t; V9 A# L4 z6 P/ I( ?8 [0 r$ F
out.close();- g. u- ~4 r) z" Y& ^! e5 `
}
" d% ]' P+ G+ {9 p7 Z catch(IOException ioex2)
6 v& \5 _) L# @! T- m3 l {
- r. I" r- i# Q System.err(this.getClass()., N2 E3 ~' F8 u' V
getName() + ".mymethod -
/ n) c& r' f9 ~' @ R不能关闭输出文件" + ioex2.toString());
% f: h$ D& O T; i) F7 o }
9 S |. C, ?3 r @3 I! R8 X- d }
; `8 a3 U# a: K% t7 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
|