- 在线时间
- 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>
$ n, Z) F+ Z' ]0 o<CENTER><CCID_NOBR>2 U" V& y; z9 R6 a* _
<TABLE cellSpacing=0 borderColorDark=#ffffff cellPadding=2 width=400 align=center borderColorLight=black border=1>
. }' ^3 E% p- k9 q5 |& u8 ?, X5 J1 {# [% c9 W
<TR>
& e/ t* u: } N$ k- N* S$ b<TD class=code style="FONT-SIZE: 9pt" bgColor=#e6e6e6>< RE><CCID_CODE>OutputStreamWriter out = ...
b, h0 H& c2 l) H k$ T9 b java.sql.Connection conn = ...
, v6 _6 d9 Z1 g' D try {: f. X& J% `+ Q) ?0 \8 A. K
Statement stat = 1 s9 ~: `9 j7 o7 ^
conn.createStatement();& R7 b" G. I" a) R) m( K) b
ResultSet rs = stat.executeQuery2 d8 Q) r% G; F
("select uid, name from user");' z0 |8 z# C5 z" r, M1 s* b8 Y1 ?
while (rs.next())* l- u2 y; Y& [5 ]$ I5 d9 i9 F( C
{
! ^4 f0 S- c1 m& Z) _; P- `* _4 `& { out.println("ID:" +
& r9 C; ]' M+ `' _rs.getString("uid") + ",姓名: "" B% e4 `0 E2 \$ U* ~/ q" m2 B E
+ rs.getString("name"));
& c$ U$ p# f7 \/ i4 y2 B }
9 k# g* k6 m9 m f* n$ l' m. t }
/ b! [3 H9 d9 ^ {* |9 m2 }7 h catch(SQLException sqlex)* |: N+ B9 i! C
{
4 _5 W$ Q/ c$ j out.println("警告:数据不完整");
# c3 A8 o/ N& ^) `& |% u throw new ApplicationException/ r8 i! `$ E5 {- S7 d9 L
("读取数据时出现SQL错误", sqlex);0 N4 C: Z3 v; i$ x8 z% @8 `
}
6 Q( u ]5 H6 z7 J" y' s/ d5 v: O2 o catch(IOException ioex)
5 Z$ W+ U& q! m {
; B* C2 |7 o4 c" | h# M# l throw new ApplicationException
8 e5 i( E& t0 Q* }0 x6 T' h" n$ W$ Q; L("写入数据时出现IO错误", ioex);
% i* E" L- v0 w0 i }) o4 s* R& Z- B9 q C2 z
finally' q+ w4 e% {( x& S U- @: b
{
2 F3 n0 H1 u% Q0 U$ [, }+ | if (conn != null) {
8 v3 v* Q7 H; E1 N: x H- l$ H try {2 a$ L7 \' H) o
conn.close();
( [5 u: C* S. |; n6 L1 O' T }
, ?4 L% t3 P q" W; Z$ @* a catch(SQLException sqlex2)' B" s i. V" u4 ?, b! _
{( w9 _4 Y( V) L) [% U7 |5 n
System.err(this.getClass().
+ X' x' q0 o. y- ugetName() + ".mymethod - 不能关闭数据库连接:: {! A, a+ k/ u5 [6 U( x7 `+ G- A6 Z9 n
" + sqlex2.toString());
( b, P( j/ X& e3 } }
0 R* O; q, V/ C+ E' f4 e }. W& d1 `: i8 E& e4 s, t* Q
if (out != null)) f2 |2 _0 {' k" r
{- s* [5 k+ ?# l2 R" H
try {
+ ^6 x/ C( Y' b/ J$ N( k' n! V out.close();
' t) @9 G! l1 O$ L }
5 \% W! d5 m- L5 G' _( N5 ~( o# p6 Z catch(IOException ioex2)# E0 R% K3 @0 e: G: G6 h$ ^+ A8 h# G
{ K( x# s7 R) p( o
System.err(this.getClass().( y u5 E# s9 d5 L, p! ]5 I
getName() + ".mymethod -
0 M: z& r! C' C/ x不能关闭输出文件" + ioex2.toString());
# D) ?& j6 [' q8 i* K( k }
2 i. n: S1 W2 x }
+ t) ~8 b) z9 D1 a- 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
|