QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4915|回复: 3
打印 上一主题 下一主题

[转帖]Java常见问题集锦(来自Sun中国官方站)

[复制链接]
字体大小: 正常 放大
god        

206

主题

2

听众

882

积分

升级  70.5%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-3-31 01:31 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
问: 如何设置Java 2(JDK1.2)的环境变量?  , x( R5 U2 N- U! v/ `# {
% o5 t+ z( F" w7 G
答: Java 2安装后,需要设置PATH和JAVA_HOME环境变量.与JDK1.1不同的是:设置好JAVA_HOME环境变量后,JVM将自动搜索系统类库以及用户的当前路径.  
8 @( p6 Z+ v: G9 uJava 2环境变量的设置如下例所示:  ' L+ u" `% i& m8 U" F/ n- B+ n% ]. K
Solaris平台: setenv JAVA_HOME Java2的安装路径  ' @# h7 j! N; M1 [0 F5 [
setenv PATH $JAVA_HOME/bin{PATH}  
: Z- `' j2 m0 mWindows平台: set JAVA_HOME=Java2的安装路径  
- o. K: P1 ?0 V, b. c5 Tset PATH=$JAVA_HOMEbin;%PATH%  
$ W5 b# L4 e2 J% N. H1 N  X
5 e; b! l$ X/ T* u* L! j9 A问: 哪些Java集成开发工具支持Java 2?  7 N! F; R% F5 \4 {0 ~0 C& j% v

1 Z1 q, g! Z/ e- g答: 目前流行的Java集成开发环境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.  # r- F9 @! G  M# Y- N# `: p; |8 f

) E& Q1 {8 j8 Q* x- K! a6 B9 l问: 如果在Netscape或IE浏览器中运行Java applet时出现了错误,如何确定错误范围?  0 l+ [# k$ i2 O) W: e

  `2 C+ j4 p" c0 T答: 当java applet在浏览器中运行时,使用的是浏览器本身的缺省JVM.而不同浏览器对JDK的支持程度也不尽相同. 因此,在Netscape或IE浏览器中运行Java applet出现了错误,建议使用JDK提供的工具appletviewer或Sun公司的Hotjava浏览器来测试该applet,以确定错误的产生是与浏览器相关.  - f9 p* q" }; T; b- P5 a
    如果applet在appletviewer或Hotjava中运行一切正常,则错误的产生是由于浏览 器不完全兼容JDK而引起的. 此时,解决方法可以是使用Hotjava浏览器或者安装 Sun公司的Java Plugin.  
# @  D; [$ e7 O8 u    如果applet在Hotjava浏览器或appletviewer中运行即发生错误,则应当根据错误 提示检查applet程序.  
# U7 \  o7 _. X* {# H
/ r$ A' Z% |+ q! _9 S问: 当用JDBC向数据库中插入数据或从数据库中提取数据时,为何有时中文字符会显示为乱码?  8 S4 \4 a. J4 @# b+ G

. ^( M( X* B/ T' ^答: 这个问题的实现通常与各个JDBC driver的实现有关. 目前大多数JDBC driver采用本地编码格式来传输中文字符,例如中文字符"0x4175"会被转成"0x41"和"0x75"进行传输. 因此我们需要对JDBC driver返回的字符以及要发给JDBC driver的字符进行转换.  
8 M& Y% n/ p7 Z7 k) D, G3 d; D& a6 C! Y: j# C: z' Q8 h5 z3 f: z
当用JDBC driver向数据库中插入数据时,需要先将Unicode转成native code; 当 JDBC driver从数据库中查询数据时,则需要将native code转换成Unicode. 下面给出了这两种转换的实现:  
, f% J7 S" r4 d6 J& w
. d  w4 K6 f; T6 `9 Z5 k' {: z# m1 q3 K% U1 v$ @/ x
String native2Unicode(String s) {  - F% W; i" m+ u( ^) c
  h9 v5 m( G" ^
if (s == null || s.length() == 0) {  
/ V  ^3 B) h/ g/ g2 e/ q4 f. P# j5 r# O$ X! G7 c
return null;  ' H( V. x5 i: u5 D: L
* }: s$ F2 b( M. o# K5 F6 W/ E
}  ; Q& s0 t& r5 H) l2 v

4 B/ B6 ~' q5 vbyte[] buffer = new byte[s.length()];  ) L1 L( u( R" C2 N2 T" M

2 K. L0 g5 N! h; y0 o( `for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {  ; K2 R, j: y- A. X5 S% |

& ]1 G: J+ ?% Q+ E, wc = s.charAt(i);  
  n" c- V9 z% d; ~! R# j) q  i+ B: m5 }* M
byte []buf = (""+c).getBytes();  7 d  A1 t" x. o; o# n
4 Y' x7 U- e' q: T5 s8 j  m- [: I
buffer[j++] = (char)buf[0];  
  V" t, u5 p. G: A0 P4 ?' I- x( P7 L9 _# c! p" p
buffer[j++] = (char)buf[1];  
5 W' p3 g5 K9 a6 K* A$ Q* e; q( P$ |% C  [) j
}  % J3 a3 u8 i0 R

2 c1 P* y; I0 ]4 ^% }else {  
! I( R+ Z. \8 a: t$ @2 K& H3 Q- T
buffer[j++] = s.charAt(i);  
  G8 _  x1 o- L  @! q5 ?7 G
4 d) U' X& l5 L/ q5 U! E) G9 W6 ?}  
* h& `+ E9 A8 B$ E; |3 \0 p9 \# ?8 ~6 ~# u8 j  J2 Z/ [
}  
- H! H+ w0 ?+ p1 s* N$ Z8 A/ ^2 `9 D7 a  ]8 c
return new String(buffer, 0, j);  3 c! W: M7 d9 D5 h( R' }0 c# }3 F% s0 j
: ^1 l4 _( w* P  d4 O
}  
4 R9 C, l, X( f+ E' u% t- b( F' o' k0 e1 b7 {. j8 {- |
除使用以上两个方法之外,有些JDBC driver如果对jdbc driver Manager设置了正确 的字符集属性,以上2个方法就不需要了.  
8 m# u# V- b) ]8 L! H  [
) x( R* f& Z6 q- N& u9 o' {$ N6 H  R3 M# w
问:  0 u7 ?' p) Y2 w5 y* [/ h, z
当用Servlet来处理http请求并产生返回的HTML页面时,如何使HTML页面中的中文字符能够正常显示?  
6 ]# G6 D8 q. C6 |- K
4 ]1 U6 w$ A7 Y# g; M( F答:  : d& ~- M  ?! X5 f
javax.servlet.http.HttpResponse类用于产生返回页面.通过HttpResponse定义的方法getOutputStream()可以获得ServletOutputStream的实例,这样用户就可以利用ServletOutputStream.write方法向输出流中写入返回页面的内容. 但是ServletOutputStream使用的是缺省的编码方式,如果要使返回页面中的中文字 符能够正常显示,最好显示地指定所用的字符编码方式. 通常需要构造一个 OutputStreamWriter , 例程如下:  
& p. a/ a0 c  J  ?& x! V9 W* r# ^# H; G7 j

0 O* @  I" N# Ypublic void doGet (HttpServletRequest req, HttpServletResponse res)  ) D3 F2 c0 a, M3 N0 C0 |

6 K# s6 q8 a+ }throws ServletException, IOException  ' |% Q7 X0 b9 k
/ g) u" b) u# X5 I' q2 n5 G$ K# ~
{  2 c# W$ z: {- t' m: u
7 n& o% O( i$ X1 W0 b
res.setContentType("text/html");  
/ Y! m8 Z. N4 b0 _& S6 w) l, X) ^( a% j  |" O6 b% N( }9 `& |" Q
ServletOutputStream out = res.getOutputStream();  / [# G5 ?* N# ?; F( E' ~

4 b# z3 g( h) B% J/ S' s& ]( VOutputStreamWriter ow = new OutputStreamWriter(out,"GB2312");  # t9 e- H2 @4 r; t. L
5 v+ g3 [4 r# A! O
ow.write("这是测试");  
% n  ?- p/ d2 [  w. E4 J# s8 M* A' {; n$ G3 A& G) E1 b
ow.flush();  
6 K  w+ T1 ^: a9 ^- A1 u' G4 O0 s* D- Z7 H9 |3 V" b( Q! }
ow.close();  6 Q% ^6 ]% J$ E7 E6 s7 q+ H% @

+ x& T; m0 _! V  Y' n}  9 y+ V2 B& S  k; X. @. a
! w( _2 T% `! k% o' k8 w$ q
# q0 v7 t) o& R
问:  
8 U; ?  C7 i2 L4 s& o如何设置Java WebServer的CLASSPATH,以包含用户的class文件?  0 _0 K6 G, n; r. n
0 x" o5 H1 U* v& y; Y
答:  
0 j; U# z& S, Q) v有两种方法可以设置Java WebServer的CLASSPATH环境变量,以使用户编写的Servlet能够调用用户的class文件.  
' k8 J0 d1 C: j将用户的class文件放到 JavaWebServer_Dir/classes目录下,在Java WebServer 启动时,classes目录被自动加入到CLASSPATH环境变量中了.  
! H9 c' f# P* A7 e修改httpd.nojre文件,将用户class文件所在的路径名加到CLASSPATH环境变量中.  1 {* J& p, d6 Y( `' Z

7 t) Q0 O: E6 X7 _4 T( U( I0 u7 K. N0 m2 h% Q
问:  
4 @6 @& x4 j: o+ [% |* {: @为什么在Windows平台上用Naming.lookup来获取远程RMI对象时会很慢?  
" I! B% d, H& x6 v: C
' {' P8 \# ?: y5 `答:  
& K% A' n- v- ?/ ^机器的网络设置不正确很可能会引起该问题的发生.  " T0 ~* s2 h  j7 Y3 N+ V, ]
RMI使用了Java网络类,特别是java.net.InetAddress类,它将查询TCP/IP的主机名, 包括IP地址到主机名的映射和主机名到IP地址的映射.在Windows平台,这种查询功能 是由本地的Windows Socket库来实现的. 因此延时是发生在Windows库中,而非RMI中.  1 `4 m: ?; n: x4 H

4 k5 _0 F2 ^1 Q. C0 S- O如果你的机器设置成使用DNS,问题通常是DNS服务器查不到主机名,你所发现的延时 是DNS查询的延时. 请尝试将RMI通信中涉及到的所有主机名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:  
: q; k2 W( M+ b
" N# Q4 x8 Y8 s) eIP地址 主机名  
5 o, ]. `$ a4 s5 ~& w6 G4 M. D
. o' R9 W% R6 h+ ]/ g如此设置应当可以明显地减少查询所花的时间.  $ ~/ g  T. r$ X: F% n& Q% z1 g
+ U' Q& z6 z% a5 U7 \; R8 P% d
问: 编写Java application时,如何设置proxy的信息,以便访问外部网站?  : p0 }$ J7 T$ {0 |: `: G/ ~. j
7 K5 w3 h8 f. ^+ _5 g/ Z
答:  
7 i8 _" m3 |9 t, q8 X. k% D, Q若在java application中访问外部网站,首先应设置proxy信息,样例代码如下:  
: t8 J& j3 Y' y- F" i1 M1 d. C: m6 Z8 E+ h

$ m8 q+ C( Q# D( R$ {import java.util.properties;  0 K0 U9 D3 z& ]0 L6 e$ [- E

, ~' c  @$ m; H( Y. A.....  7 W& k5 Z' r2 G7 V' g! I2 E
, @$ ^7 E+ _0 w
Properties sys = System.getProperties();  7 a% Y* }% H, A# ^, z& G

4 I9 [, h9 T, @" `! T4 m8 ^( Q/ hsys.put("proxySet","true");  
8 R3 U5 A, {' L, w+ M* t* S2 L& y: k9 U7 H/ @; F2 n3 H2 y
sys.put("proxyHost","myHTTP.proxyserver.com");  
" b5 Q( X& J7 b% k* ?9 l
. z3 ^, G& K  s2 m* u' ?$ D( p, Tsys.put("proxyPort","80");  ' M8 d+ }2 l- g! N1 L* H
3 r5 {# ~, x7 y) T/ M; L
System.setProperties(sys);  
7 S5 Q  C) P% `+ |; d
9 v$ n9 v4 [2 f# I2 }2 ^4 z# L' M( R- @  J
* R8 a: K8 d& U+ Q( N' W* }7 X4 K  z3 |
u = new URL(website);  
: `$ X, o$ c  z; o% d- Z" K2 H0 L+ ^4 Y
connect = (HttpURLConnection)u.openConnection();  ) z: M- N2 P( W

+ Y2 L. [2 \1 D5 r2 g.....  . T2 H' D& R' }" }
( D2 I8 `0 M( j9 F7 G
问: Swing组件JList的列表数据修改了,如何通知JList改变显示?  - q! L  H+ q4 N% E/ U) x

% w/ o3 a9 F: @: v" H' }) {* W, y答:  
* _, f1 m) o. WJList组件有一个单独的显示模式ListModel来表示JList的显示数据.  
* U. T' Y2 D4 B1 y6 ^JList创建以后,JList数据元素的值及数据元素的数量可以动态地改变.  
1 B- y+ v6 ]9 T- Q0 G! O- JJList在它的数据模式ListModel中观察数据的改变.因此,一个ListModel 的正确实现应当在每次数据发生改变时,通知事件的监听者.  , A8 c$ |% S9 F) @" B9 f2 Y
当使用构造函数JList(Object[])创建一个JList的实例时,系统将自动 创建一个DefaultListModel的实例来存储JList的显示数据, 可以调用 DefaultListModel中定义的简便方法来动态地修改JList的数据,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改数据的同时,将通知JList关于数据的改变.  
+ ^- A5 [* g9 X7 v8 f) L4 V/ t0 ]1 M9 v2 e2 a+ C4 Y1 _
问:  4 B, M. r! Y9 S9 n
在Java applet中如何实现一个模式对话框?    j- k1 Q) ^' E/ e( @# Q

8 \& q8 G; p3 h( Q/ k答:  
. j1 V: q. M$ K  y! l在Java applet中实现模式对话框的关键就是在创建一个对话框的时候 要为该对话框指定一个正确的父窗口.因为Applet是Panel类的子类,不 可以作为对话框的父窗口,所以首先要获得applet所在的窗口,作为模式 对话框的父窗口. 样例代码如下:  4 X3 D0 F5 _9 y  [' Y

$ ]2 J0 K& Q' _; Q" v9 T. z2 p$ }* S5 x6 `# \
.....  " `3 [# q' h' M

1 _! z. p# W: z/ E* N) [" R6 L, FDialog d = new Dialog( getParentWindow(comp),title);  
3 t& W$ u. H# U6 Y" m- S* w1 }) i
+ o$ N9 D, U  ?& P// comp为applet上的任意一个组件  , R# \! {0 r2 s/ L

0 R5 `. J) x& Q....  * G0 k* F. l# i& W1 n

5 W4 L$ b- R" l4 N4 h
- X" P( T2 x# b8 D$ R2 X
: |7 a* X6 |. Rpublic void getParentWindow(Component compOnApplet,String title){  
' i7 s* T+ g; F0 p
7 G/ {, L5 ~" O& |Container c = compOnApplet.getParent();  4 Z5 i2 h6 c. V$ z! x* I/ y& d
, U' t1 G. O9 o+ p' \
while (c != null) {  1 @/ `5 w+ z4 t# c# p+ f

0 k/ f* |( V4 f# Oif (c instanceof Frame)  
8 z3 z! e  a" I* y$ I& t+ O0 m
4 A1 X) ~7 r) z/ t' Z! areturn (Frame) c;  7 G7 F; T1 M; b6 v5 D4 w

6 n- f9 A3 a. i8 F( ~, e, }c = c.getParent();  
5 R7 a! N, D* F8 C$ m( H! V  c. ~; f7 t9 P2 o5 r) e
}  * ~+ n2 n% [5 I( ^
+ [" j! j& h6 |% @
return null;  7 N6 N( ~2 K- C1 ?1 m

" A  q0 W( D& w( @) c. X2 m" v}    M; a5 _1 V$ a- [! A0 n
5 u5 L7 q% O( E$ l/ q
问: 在Java applet中如何显示另外一个HTML页面?  
) {8 b* K" g  ?
' L( s% w0 S2 n) r6 R1 m$ U答:  ! J, O$ h2 d2 e  m+ K
通过java.applet.Applet.getAppletContext()方法可以获得与该applet相关的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的浏览器显示另外一个网页.  
, @& P4 l0 y0 Y' y+ `1 V$ s; G; V7 I" m$ j
问:  0 a! N6 k. ]8 J0 n4 U  h4 B
用JDK实现的签名applet,可否在Netscape或IE中运行?  . `2 i# c- k9 Z+ r0 Y- S

9 Q  N# y! K5 M" f: K; ]答:  0 x+ n# |) \) C5 O
用JDK实现的签名applet,不可以在Netscape或IE中运行,但是可以在Hotjava浏览器中运行.  ! v1 s' h0 r! R7 \2 z

) _" C6 f6 ^7 Y! U' }不同的浏览器提供了不同的签名applet机制,如Netscape提供了zigbert工具和 Capability API, 而IE则需要使用CAB文件. 但是,无论是Netscape工具产生的 签名applet,还是用IE产生的签名applet,都不可以在其它的浏览器中运行.  
3 B: A! L9 n' i7 O! z6 G/ Q$ P) I; ~
如果要使JDK产生的签名applet能够在Netscape或IE中运行,解决方法是在 Netscape或IE中安装Java Plugin,则用JDK实现的签名applet就可以在这两种 浏览器中运行.  
/ q0 t6 R% `' B
* ~3 v9 C% A9 b& N) ~问:  0 j* j5 ?3 o- ~( c4 z2 `9 }
用JNI技术可以从Java应用中调用C程序库,但是如何使该C程序库可以调用另外的C程序库?  
* ~+ V, N( V, l: _! c$ _7 i& n& z0 c, G4 y, o) `5 D( s5 s. u# f
答:  7 z4 K/ z7 @/ B) i
如果一个被Java调用的C程序库C1仍需要调用另外一个C程序库C2,那么在编译C1的时候应当联接程序库C2,步骤如下(Solaris平台):  
% N3 t3 }, L. }) c" _. T编写调用C库的Java文件,并编译.  ( H6 {4 g' [; g4 A. A8 j
javac java文件名  , y4 ]; }, n1 l9 q7 u5 C
! S4 H, d  m6 r7 [/ p( h  H
8 i- T1 w; y5 S) n" z' E2 m
产生C程序头文件  
: n' o. y- `, `4 q' Q6 G0 vjavah -jni java文件名(不带后缀.java)  
( ?' {5 R' N, }. {) J3 |" O: ]/ z& D7 g) @2 U

  ~6 T6 [; s& T2 i4 u编写被Java调用的C程序C1.c,以及被C1调用的C2.c,并编译.  " y2 J* S( D* i" w- c3 ~3 ?9 k
cc -G -Iinclude路径名 C2.c -o libC2.so  
( L5 u) j; U8 }cc -G -Iinclude路径名 -lC2 C1.c -o libC1.so  , E! }, d) y0 K4 |# E" x' [/ ]

% O/ v- [' [5 x) `/ f) Z
% h3 j# v2 U: u- r设置环境变量  
% Y5 q7 y. b0 {& ]' rsetenv LD_LIBRARY_PATH libC1.so,libC2.so所在路径  4 j% ?" P# K" Z7 ]
{LD_LIBRARY_PATH}  : j& h/ U* M& R/ I: ^' a. T/ `
0 K2 K4 v3 T( B% Z! T
$ I, i: s) T% K  r' l. e/ Q2 T! e
运行java应用  
  j) V5 h% E# @3 I4 [1 G' \% @' v
( V4 W8 ^- q5 X2 u0 X
* o  s3 z: i% K" Z2 c: }问:  8 L/ o0 S' e0 U& c
在Java语言中,如何列出PC机文件系统中的所有驱动器名?  
* h7 g& s, t" l, U. w) p  _" k) e. p
答:  * N  l+ ~! W1 h
在Java 2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.  0 }5 w# d1 r% r1 ^( m$ \/ S* g

! a$ |6 b4 p6 d& X, Z/ N" ~问:  3 Z# @  b; w, i) F2 m
为什么Runtime.exec("ls")没有任何输出?  ; ^) z9 C: S! r! O
2 }7 d/ q: v, \) Z* [1 W1 I7 y) Z1 K
答:  7 x. C( P& ?( f5 p5 U5 D4 g
调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息. 由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向 子进程输入数据或获取子进程的输出. 所以正确执行Runtime.exec("ls")的例程如下:  & [' G$ r; _( A. N( |: e% d

% [9 w2 M6 F8 h. S
3 d7 }4 s& N! ?" f) y  h* ~try  
- @( n2 v+ T; R, G0 ]) [5 J% U  f. l3 H% B
{  
2 N6 v5 t8 x& c+ I; V! k+ ?$ x0 y
( T! C# k* W4 Q3 H1 vprocess = Runtime.getRuntime().exec (command);  
+ i: ]% \4 Z, P' K* ~8 v
4 M* q( R5 D$ G  u, CInputStreamReader ir=newInputStreamReader(process.getInputStream());  
& h+ [! _- C0 b) |: b4 ]) b" Z! |+ I. J: J* S6 L
LineNumberReader input = new LineNumberReader (ir);  
8 H- r9 j# n7 A- c( R; V( S' m0 f& a6 ~: S
String line;  
1 C" a+ H4 i7 T+ x( Q- u
. k+ H4 s7 @3 p8 B4 ]7 x3 z# u! mwhile ((line = input.readLine ()) != null)  
& j. Z# Y0 T( ~% K% c) n4 w) T& }9 U7 H+ ~% E# F
System.out.println(line);  
) H5 n  \5 p7 W( o8 p. s! _( d$ Q" U
}  
) `" Z; ?4 F# M! W, `- v0 D
' l. r5 f. z4 T% f- Ycatch (java.io.IOException e){  
8 R" s( f  {' m
0 u, R4 i* W! Y/ E3 L4 [- f$ S8 S) ~System.err.println ("IOException " + e.getMessage());  8 ^! W0 ]- p+ K5 l6 m6 B# X: M
+ m5 |* t8 Z3 O; t
}  6 r3 D1 ]/ ]0 x2 a
$ e3 m5 K$ l. P' [. |  T# G
& s$ U8 g4 J3 i0 {5 H
问:  
4 I& `- O  X6 F, c6 Z: {1 G- t0 p如何产生签名applet,以使applet能够访问本地资源?  ; O6 ^' L* s. \8 H
6 m0 [5 M0 N3 i5 f$ O' h
答:  
+ |& H. l+ W- P在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料 请参考: http://java.sun.com/security/usingJavakey.html而java 2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java 2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:  
) t# u3 q6 M! s. c: _( Z" Y/ r! ~
( o. b) ^0 |+ b
. k6 L* ]" C0 u) |/ A//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中  * Q% X# P- F- x0 s

7 o, Q1 H- \# n& m! \! D) \keytool -genkey -alias joe -keypass sign12 -keystore joestore  
+ Q  W9 y7 |% z9 w8 |
* Q3 s1 A) X" n! N, @, l% `- ^" N//将SignedApplet.class及相关文件打包成jar文件  
! ^# K! H9 l4 j* }# }8 n0 S/ l& y/ c, L- n) M
jar cvf SignedAppletDemo.jar  
. K, ?; I2 U0 b: Z. p& p
8 i8 R$ N, k" ]. ?//利用keytool生成的自签名的证书产生签名applet(jar文件)  
2 _0 |/ A% R" T
2 z/ d* T3 F/ k( w7 L% ]jarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe  ! ~, ~2 i) h0 l& r' o
$ j0 p7 O- ]4 ]1 a0 Q+ v
//将自签名证书从keystore中输出到文件  
( ^0 y  m/ z, G: v9 `
7 b$ h& V  ^8 G( [9 j. Pkeytool -export -keystore joestore -alias joe -file joe.cer  
% V/ _6 W! z" k1 L% t) n7 q
8 l8 L6 ~9 X! J* f4 S$ c" m
: A& P# F" U( }  u; D" V) p' D  S/ m1 i) S
而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行  ! H8 E1 o7 }, O* i5 {
) F* m" \0 T3 Q5 G! J$ w
Joe编写的签名applet:  
0 r% _) }' c( S# s4 H3 X* i4 |4 ^2 J0 a( {% b8 V; J: s8 \
//得到Joe的证书并将之读入到密钥库中susanstore中  
! p7 j- k: e; u' [0 m( w4 Q. ]$ h% A1 e. R8 L0 Y9 }
keytool -import -alias joe -file joe.cer -keystore susanstore  
% x: g( j3 X  x5 I3 o' s( v; S! C" [7 W
//运行policytool产生满足Susan要求的policy文件  
+ g2 z' C: P; d3 c% b9 U
/ o" J: q( Q5 Q) O6 W1 V+ y- |policytool  ) N. R0 I  g' ?9 g

. K; e6 o# {& M6 H2 o5 }//用appletviewer运行之,或在浏览器中安装java plugin来运行之.  , Y' ^9 r2 c. @1 X6 J3 {$ S$ I
  s& o3 u1 {' x: x$ S, f: _
+ {. j6 y: V( ?# J! {

2 q7 D: G, i2 D5 U  b% j% M! ?- P* h关于签名applet在Java Plugin中的部署请参考以下网页:  
4 ^0 \2 N1 m: B7 l: G9 v) f6 l9 G( V
http://java.sun.com/security/signExample12/  
" D. m( w3 N+ E  g6 l
" q+ @; H0 P+ ?2 v2 _3 U6 v9 K; [  w8 S
- z- N; W0 ~$ _) U. D- w
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以  
( @/ V$ R% f7 G' n. h  l8 c
$ m: k2 T- w6 m! ?' f使用keytool -certreq向商业CA中心申请电子证书.    g" V1 P# k4 K) {: G( ?" c

; m6 I1 x) }& q4 \! @8 u4 `  z7 k  u) F5 }/ p6 ?1 @# u' M

: P: v2 m/ Z. p6 Y3 t% H2 ~$ |+ P/ s, [/ c
问:  
& w' {( z& o. m若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?  4 e9 v& M  m; ~) F6 C( ]: `2 C. E

7 P' M# D6 w. z; A- m* I答:  
6 L4 n5 S$ h" Y. d# p使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.  
( s0 T/ {* a( Z6 E8 g' c8 _' c6 x* I% R9 Z
问:  7 c7 v3 a. n  L* i) a6 q; K# J
对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?  
! [+ u' S0 n6 @3 }
3 I* L3 o" b6 x: J+ }3 T2 V答:  9 X* f) E4 Q: }
目前,没有直接的方法可以将对象写入到随机存取文件中.  
7 T3 B/ v: D) K# b; `6 H& p% n但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误. 例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.  ; u0 [. T# C( E2 T& U# @
7 v5 q% i5 A( A5 Z# c
问:  
( W* u; H) x7 n- V% y4 u+ l运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?  
: L) t; n6 z- C5 `
5 h  O$ t! Z+ s! y# e0 i2 j8 O答:  - g$ g7 T: H: [. b. J# j# A
可以. java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(int port)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于获取名字服务.  
4 q# @/ m* @6 H' R1 M  r
( }0 \$ I; ]8 Q" s+ c" k! P问:  ) Z8 Z* h; d1 h/ Q. t' v" u
使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?  + ]# A5 e% ?7 e( ?0 f
/ k1 s8 S, j, @: p( ^  b, f& a
答:  + @7 V; K! ]8 `! Y5 @  B
使用如下方法可以获得PrintJob的实例用于控制打印操作:  : N* }- ?0 W( i: S4 A% u
; V. t6 h+ {8 M
' @' ]) l% s. H, }! k, X6 E
Toolkit.getPrintJob(Frame f, String jobtitle, Properties prop)  
5 ?, O" @/ D- K) T
) k" @+ N5 n8 F' @' u那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:  - p  G6 P. S" i7 T
/ R4 S/ P7 ?, E
awt.print.destination: 可以是"printer"或"file"  
6 N( u7 d3 v1 g6 Z4 ]" ?3 r9 z/ f# s, M2 h
awt.print.printer: 打印机名  - ]# L/ M6 l2 D  v7 x4 J! s

% R3 K( H3 R% E9 `+ D1 }1 @3 A% hawt.print.fileName: 打印文件名  1 @  d( C" Z4 A( l# v- e' R, V

0 J/ n2 o/ U. @+ O5 t0 m, Uawt.print.numCopies: 打印份数  & \+ R% u* b7 @1 T5 X+ `% r

- C7 B5 ~: D4 I4 ^, I  Iawt.print.options: 打印命令的打印选项  
9 }* @4 f# r3 w" p& w" X
2 V7 B/ m7 ~- ?1 `7 f) kawt.print.orientation: 打印方向,可以是"portrait"或"landscape"  9 u+ G' P) H2 Q$ ~

6 ~. O) e6 s, ]+ X) Y/ pawt.print.paperSize: 纸张大小,可以是"letter","legal","executive"或"a4"  
% p: T" [2 ]. C. y7 w! [5 ]
7 @9 j6 N. S$ o" j, Q6 r  i( G1 {) V4 F1 O

0 |' k. h' {2 L: B+ y
" {' B, ^& w! n& A% ~' J# c  h3 u; \# k, [7 b
3 U9 @- ?) v/ p) I% ?
问:  
8 ?( F0 c$ `/ j/ s2 s" t在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?  / O* r- `+ I( s( n5 h% M" w
  \4 h# c- b- m- D
答:  
, [" M. n) S* c: K' l3 f, s0 nThread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.  
0 J/ D) ^4 Y* ]# v6 W! N3 U2 ]* t: _( _3 d
因此,在Java 2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.  
$ J" F7 V) O& f5 S/ B
* H0 b& Z9 w: m问:  3 _4 |+ `2 [& W# M. A
使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?  2 M( l9 k; c8 i' R9 ?$ s
9 i+ j9 Z3 \8 ?+ [
答:  8 Z# t4 h, O+ n* ~( `5 J, M3 `
在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java 2中,ResultSet类增加了如下方法支持数据指针的移动,包括:  ' ?  f2 c' r$ b  n6 G) g( G- D
4 V" m' X; I& X5 U

3 s) [  I* C, |ResultSet.first():将数据指针移到结果集的第一行  7 b9 [7 i, f$ L  b5 g' F8 L

. r8 X0 E  t& t, W5 EResultSet.last(): 将数据指针移到结果集的最后一行  4 a% V; P. U5 n1 R
4 Z+ q; H; i1 [
ResultSet.previous(): 将数据指针上移一行  
7 `5 q0 s) E* x0 _& E) h! @5 ]: d# J( P7 f5 R" G

1 t2 H- ^1 k2 \. a以上的方法定义在JDBC2.0的规范中,所有支持JDBC 2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC 2.0 .  6 S1 T7 O1 C0 N

8 }  P; o/ L7 D4 W
/ s4 z( r, ~0 E4 I问:  . T9 V; \7 x. x+ x* T
哪几种Web Server支持Servlet?如何使IIS支持Servlet?  
0 `! c+ ?! x( t5 C. q
1 f- C7 ^- o/ c/ J* M* z答:  3 B. [" r* {/ F- e2 B
目前,支持Servlet的服务器端产品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.  
/ q7 Y1 T* k! A% e. T' G) l& |: h# y  a- T2 O8 _
此外,一些第三方厂商也开发了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能够运行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.  
# v+ C; d+ Y/ u# r  r: n+ {1 I/ O
问:  6 {7 B! W) G2 A9 M" s* Q: H
如何在Java应用中将图像存储到图像文件中?  6 _1 {8 H1 a8 b7 ?1 S. r
+ R! N8 t- i% `& O/ {) g& m
答:  
+ z9 W9 \$ I: r- @2 m% dJava Advanced Imaging API(包含在Java Media API中)允许在Java应用中执行复杂的,高性能的图像处理.JAI API提供了存储图像的能力.目前,JAI API支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:  
7 I: _' Y0 y7 [
, i1 J4 v0 Z2 q6 t0 N- q/ y$ n  B( z0 f1 e! `
OutputStream os = new FileOutputStream(fileToWriteTo);  
5 t9 ?2 i" H/ Y+ J6 L$ h0 @3 b5 t! @* y/ M7 |
BMPEncodeParam param = new BMPEncodeParam();  
: h  ~, @/ B/ A. F" S  `' U
" _" J* f  k; H: rImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);  # Q; n+ g) t7 v2 I4 A
+ {0 j& L2 G; D, F: ^+ U; L) }
enc.encode(img);  1 w$ S1 ]  Z% T  W

7 i6 j) J! M* N- _4 b4 Jos.close();  
( E  {7 ~: m7 F: g: k& \5 Q$ G" t7 c
有关存储图像文件的编程指南请参考以下网页:  
. b5 ?7 {) u, ?$ F# w
! f6 P( t* F! ^& o. N5 V7 jhttp://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/  2 @& |$ @  Y- s) @
0 d/ |) G  P8 s, e2 h; ?, b
9 @6 W- ^+ ]& D" t; {" j& U4 ^, E/ |
: T* e: J4 D. U. m3 B

+ D6 a- q' p5 ^" k$ r+ ]) R* C问:  " N- Q) ~+ s, s( H0 K
如何用Java语言向串口读写数据? font>  + z$ C# u- K) S
1 m/ a+ Q! z& D3 ]
答:  
2 h* Z3 [3 q) TSun公司的Java Communication API2.0可用于读写串口,它支持RS232串口和IEEE 1284 并口,提供了一种与平台无关的串/并口通信机制.  
8 \2 l( G* H. ?0 o+ N6 o
5 V+ s9 c5 a7 R) w7 x详细文档,请访问:<a href="http://java.sun.com/products/javacomm/" target="_blank" >http://java.sun.com/products/javacomm/</A>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
如果我没给你翅膀,你要学会用理想去飞翔!!!
wangyu249        

1

主题

3

听众

54

积分

升级  51.58%

该用户从未签到

新人进步奖

回复

使用道具 举报

wl820609        

1

主题

3

听众

23

积分

升级  18.95%

该用户从未签到

新人进步奖

回复

使用道具 举报

deven1985 实名认证       

23

主题

3

听众

2433

积分

智慧的蓝色小毛驴

  • TA的每日心情
    开心
    2011-12-5 23:03
  • 签到天数: 106 天

    [LV.6]常住居民II

    自我介绍
    200 字节以内
    不支持自定义 Discuz! 代码

    新人进步奖

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-21 16:40 , Processed in 0.412746 second(s), 70 queries .

    回顶部