QQ登录

只需要一步,快速开始

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

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

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

206

主题

2

听众

882

积分

升级  70.5%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-3-31 01:31 |只看该作者 |正序浏览
|招呼Ta 关注Ta
问: 如何设置Java 2(JDK1.2)的环境变量?  
: [* B# ^  m/ y6 b  d& [/ `% ?+ g, z% w# \5 _4 `
答: Java 2安装后,需要设置PATH和JAVA_HOME环境变量.与JDK1.1不同的是:设置好JAVA_HOME环境变量后,JVM将自动搜索系统类库以及用户的当前路径.  
/ D2 E8 \) ~8 W$ I8 l7 F' LJava 2环境变量的设置如下例所示:  
) [+ P5 j' H/ Y) m/ e# tSolaris平台: setenv JAVA_HOME Java2的安装路径  7 e) M9 v7 ?- p( k2 g4 O
setenv PATH $JAVA_HOME/bin{PATH}  
) O* b5 u) z4 y- T+ J5 Z. yWindows平台: set JAVA_HOME=Java2的安装路径  ' t9 e. w# j, x' r
set PATH=$JAVA_HOMEbin;%PATH%  
" [* D( u5 m* W! A
! j" R  h: V4 S# r9 q- q1 ]问: 哪些Java集成开发工具支持Java 2?  7 u. w- G* [* k4 n" h
: T2 n& g* F9 s3 h+ m1 o
答: 目前流行的Java集成开发环境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.  
" P! U- E4 K, `  i( z
, T! y6 F& q" u( F问: 如果在Netscape或IE浏览器中运行Java applet时出现了错误,如何确定错误范围?  
" j# ]5 O2 m6 k# K7 U0 w" Z5 R8 }5 |" R4 U& C8 w- Z4 R. \
答: 当java applet在浏览器中运行时,使用的是浏览器本身的缺省JVM.而不同浏览器对JDK的支持程度也不尽相同. 因此,在Netscape或IE浏览器中运行Java applet出现了错误,建议使用JDK提供的工具appletviewer或Sun公司的Hotjava浏览器来测试该applet,以确定错误的产生是与浏览器相关.  . @# ]: s1 a% f  J4 _4 ?
    如果applet在appletviewer或Hotjava中运行一切正常,则错误的产生是由于浏览 器不完全兼容JDK而引起的. 此时,解决方法可以是使用Hotjava浏览器或者安装 Sun公司的Java Plugin.  
; e7 C2 h* s# R3 K$ z" q$ P    如果applet在Hotjava浏览器或appletviewer中运行即发生错误,则应当根据错误 提示检查applet程序.  8 B, ^/ f2 U4 i9 f
" ?3 ]1 I) r$ W  J6 w. g
问: 当用JDBC向数据库中插入数据或从数据库中提取数据时,为何有时中文字符会显示为乱码?  
" [- R3 A+ Q+ d% W1 U! a
3 D$ R% x$ i" d" y+ |0 a& _答: 这个问题的实现通常与各个JDBC driver的实现有关. 目前大多数JDBC driver采用本地编码格式来传输中文字符,例如中文字符"0x4175"会被转成"0x41"和"0x75"进行传输. 因此我们需要对JDBC driver返回的字符以及要发给JDBC driver的字符进行转换.  4 C, |* Y8 f% Q2 }

' ^. X; Z0 `) w- _# d% @当用JDBC driver向数据库中插入数据时,需要先将Unicode转成native code; 当 JDBC driver从数据库中查询数据时,则需要将native code转换成Unicode. 下面给出了这两种转换的实现:  . H7 ^% C0 w) x
# W% w5 ^, ^, w- r3 O8 Z; M
$ v- m$ a; P3 z2 j; y
String native2Unicode(String s) {  0 P1 |# V) o- D0 `1 a1 P! s3 m- e$ X
5 j/ e2 W4 o1 B
if (s == null || s.length() == 0) {  
2 ?2 Q2 J6 @9 o5 S. B. `) ^8 F3 h
return null;  / K. _& ]0 [  j( u2 _

: b& s, J1 x3 X& B; Z$ C, @}  , c' X' @7 p6 T% M; r: o

) a3 J  N2 }% f! J7 ^) ebyte[] buffer = new byte[s.length()];  
5 U+ C$ Y1 U  L3 d  N' F6 Y3 B6 s0 m! h  `6 s7 V' ?
for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {  
9 x$ n) `$ ^4 v2 O8 }5 n* w  U* u2 M7 J5 K' m% z
c = s.charAt(i);  
3 K+ [. w# ^7 b
* ~, A/ A5 `7 F* A. Vbyte []buf = (""+c).getBytes();  + Z+ P0 r/ Z* q( h! J
# ]  }+ {0 x' z$ J" ~2 D# G
buffer[j++] = (char)buf[0];  3 j- M! g2 N- T$ e3 T$ F+ `

! T  g8 P: S; s* Abuffer[j++] = (char)buf[1];  / P: B8 g$ K  t0 z0 Q9 d

, X6 [7 p# |* S0 ^2 L4 ~/ P. L}  6 _& U. a' p7 r

& Y; Q" V" Z' b7 F0 i. U/ r0 Qelse {  2 j' w7 ^3 |' J" u( @7 G8 ~
, O1 u, p5 B4 L
buffer[j++] = s.charAt(i);  
- s8 ?9 n0 w& o- T  W$ X
* J8 f0 d, v7 I6 M+ a}  . s- C* x; t( F9 S3 u- k: z, A& ^+ K
- b& H( H$ R6 w, w; V& x
}  
. j5 j8 v7 A% @9 O, [
; a& M3 I$ u0 O8 X( Breturn new String(buffer, 0, j);  4 M+ a# k: p0 H+ ?& t5 o( L- G
4 y7 U' c! m) F: T7 B. |
}  
4 z2 h- O: N  o' G. y7 @1 c4 w- S" d/ ~5 b; b% n) x8 k
除使用以上两个方法之外,有些JDBC driver如果对jdbc driver Manager设置了正确 的字符集属性,以上2个方法就不需要了.  
& I6 m3 B3 k, e6 m- t7 h, z/ v  g. z4 v# N, k. S

- T/ \* i( w- V% V$ _问:  $ i+ C/ ?- H$ Y( |$ R
当用Servlet来处理http请求并产生返回的HTML页面时,如何使HTML页面中的中文字符能够正常显示?  # y: c7 z* S7 k4 t( q, D2 D$ X
3 G& v- q) v( i( v
答:  
% w" v  @/ t2 kjavax.servlet.http.HttpResponse类用于产生返回页面.通过HttpResponse定义的方法getOutputStream()可以获得ServletOutputStream的实例,这样用户就可以利用ServletOutputStream.write方法向输出流中写入返回页面的内容. 但是ServletOutputStream使用的是缺省的编码方式,如果要使返回页面中的中文字 符能够正常显示,最好显示地指定所用的字符编码方式. 通常需要构造一个 OutputStreamWriter , 例程如下:  + q) P, @. o$ N/ s

, m( R7 `# R. b$ p2 v
/ W5 f9 x; [6 [public void doGet (HttpServletRequest req, HttpServletResponse res)  7 E2 Y1 {) G; s' E

5 ^# n2 v$ F* x# X! _7 V+ v' Othrows ServletException, IOException  7 N+ E/ v/ }4 ]" }8 r

% j- P* n* ]2 g{  
# l; Z( P2 h  E: ~5 o/ o" A: b1 O- N. C7 n* N! F1 K! Z
res.setContentType("text/html");  & O" u* C' B8 N: W, v
& I% K6 P- W! E6 k
ServletOutputStream out = res.getOutputStream();  ! r# ^4 c# p- z; v! W9 d# H
3 e' w2 ?( P- @' ~. \0 V5 n1 G
OutputStreamWriter ow = new OutputStreamWriter(out,"GB2312");  ! m: p6 O9 |  L& I' T# o- Q
" G) {7 d. z; j9 h$ J
ow.write("这是测试");  " E9 X( J; G( I  |: f( {

$ ~8 s+ E, \" V; now.flush();  # U4 l* M- `+ W% M

' u; V: t' A/ \6 @ow.close();  
; V: c# b8 X3 n3 Z% D0 ?& T1 t/ A3 Q% Q8 q4 n! t
}  
7 k1 M5 G  d% z1 O' M7 L5 g, V* r
2 v2 U6 u$ R! m6 f6 Z
+ s- \$ i8 W* X4 a4 \- v) w问:  
  g0 F  ^( ~* i如何设置Java WebServer的CLASSPATH,以包含用户的class文件?  
* ]. S/ }7 d+ K7 b* G# e! l) i: ~2 G( c7 g
答:  / n( m8 U$ B) E" h4 A: e
有两种方法可以设置Java WebServer的CLASSPATH环境变量,以使用户编写的Servlet能够调用用户的class文件.  
* E* W* ?3 J! U, K7 k6 E将用户的class文件放到 JavaWebServer_Dir/classes目录下,在Java WebServer 启动时,classes目录被自动加入到CLASSPATH环境变量中了.  7 b$ R2 D$ J( F
修改httpd.nojre文件,将用户class文件所在的路径名加到CLASSPATH环境变量中.  
  v% I# |4 `/ O/ T6 E8 y
5 h4 L. l/ B* I( s; a! \4 r# o5 W0 n. I' `" N) U* ?
问:  
- n# H3 f+ Q2 h; c$ [* u. a- ]5 y4 Y为什么在Windows平台上用Naming.lookup来获取远程RMI对象时会很慢?  6 k  Y, c- Q- u* z) y3 T  @4 v

4 ~- u8 e' o+ A& Z3 W% |) p5 p答:  ) B: _# u5 G% h: j; }  {7 q  C
机器的网络设置不正确很可能会引起该问题的发生.  
* \( E( R  Q% N9 [6 e. p% W0 Q; ~* uRMI使用了Java网络类,特别是java.net.InetAddress类,它将查询TCP/IP的主机名, 包括IP地址到主机名的映射和主机名到IP地址的映射.在Windows平台,这种查询功能 是由本地的Windows Socket库来实现的. 因此延时是发生在Windows库中,而非RMI中.  
$ p  k3 s1 R& a# V+ P3 h" W* S! W! F) B9 {$ E  }; l& V2 O
如果你的机器设置成使用DNS,问题通常是DNS服务器查不到主机名,你所发现的延时 是DNS查询的延时. 请尝试将RMI通信中涉及到的所有主机名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:  7 z+ ~7 U. Z' H

1 W& w8 U( i) u* s# N* RIP地址 主机名    _: w% F# Z7 z) r% B$ p

8 x% d2 l1 E# D$ A; T2 G7 A如此设置应当可以明显地减少查询所花的时间.  8 V1 F, a3 u- t9 L0 p

8 V7 I; D2 R7 n$ X+ G/ [问: 编写Java application时,如何设置proxy的信息,以便访问外部网站?  
2 e6 E0 s( _( m, i- `# E* b$ s; P% a
; o: U2 x1 g4 K8 c4 y& w6 p3 e6 [9 e答:  9 ^1 v- y2 R2 |7 \$ R$ V. B
若在java application中访问外部网站,首先应设置proxy信息,样例代码如下:  ( z) w/ p. e5 o
5 D( M+ g, m; X; o, y/ c% ~

" G5 ~* B+ Z: t+ \3 S$ `1 b3 @$ Simport java.util.properties;  
! ]9 v9 r" {2 @" X9 Z, N- G, {1 v! D7 u& X* ~8 o  \
.....  6 X9 C: b, W) x* L3 A& q/ j. ~" t
; d7 S* N* _# Y4 s9 r. S
Properties sys = System.getProperties();  
$ m/ I4 H& l% f; m( G0 \
9 B& z1 h2 k/ `/ h) Jsys.put("proxySet","true");  6 E8 F$ \+ S( R$ F, Q
# q( z  B& X) f) }" a
sys.put("proxyHost","myHTTP.proxyserver.com");  5 d9 |" Z1 s  F( p
% g- X; t' t4 @  k2 ~2 f
sys.put("proxyPort","80");  
6 p: f+ J6 E% R' B* Z: T. _. A/ V' i6 J0 ]/ F( ~
System.setProperties(sys);  - B. E) H2 n0 O6 u# h
& Y( F3 Q& N4 A# L( [7 r2 R

/ _2 I9 }* M+ W0 h' F6 r1 n- t' j
u = new URL(website);  
& F7 w# M. e5 U1 T, R% X+ u, F" x, u9 g; e
connect = (HttpURLConnection)u.openConnection();  
- M3 J% \) q0 }. A
: X- K0 X8 R# M3 f.....  + r( M6 C$ |/ F: z

. L3 g" Y; w) e4 L问: Swing组件JList的列表数据修改了,如何通知JList改变显示?  6 }( Q0 s. J/ k7 T$ A9 I# o
/ L0 x, N0 g% |; l1 b
答:  2 x: P2 l; [8 @! j3 s
JList组件有一个单独的显示模式ListModel来表示JList的显示数据.  
& e& ]! m3 @; o5 ?! j. T2 F% `JList创建以后,JList数据元素的值及数据元素的数量可以动态地改变.  ( M% j+ `& H6 u/ X8 }5 ~" N
JList在它的数据模式ListModel中观察数据的改变.因此,一个ListModel 的正确实现应当在每次数据发生改变时,通知事件的监听者.  0 Y( |+ M! D/ C+ J: s, F4 N- }; r
当使用构造函数JList(Object[])创建一个JList的实例时,系统将自动 创建一个DefaultListModel的实例来存储JList的显示数据, 可以调用 DefaultListModel中定义的简便方法来动态地修改JList的数据,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改数据的同时,将通知JList关于数据的改变.  
0 i% l" M, d& x1 h3 e$ T+ l9 N& N" `) F2 \' c: j
问:  , R+ s' \9 s6 h  M5 u
在Java applet中如何实现一个模式对话框?  
0 F% r# _0 m2 k# b& W) o. i
- c, C. W6 q1 ]: p- A4 i答:  
7 L% ]0 N& O$ n在Java applet中实现模式对话框的关键就是在创建一个对话框的时候 要为该对话框指定一个正确的父窗口.因为Applet是Panel类的子类,不 可以作为对话框的父窗口,所以首先要获得applet所在的窗口,作为模式 对话框的父窗口. 样例代码如下:  ' p1 |2 |) I. p  @: K

3 q, }! G" @# w3 _6 }( l; R  V2 n: V) L$ B' C5 _4 ~5 {
.....  ) |( e! [9 y! n0 Y. G( z

9 a* R( j% H, ~/ z9 bDialog d = new Dialog( getParentWindow(comp),title);  ) r( B! v8 Z  b3 T6 W" J" _: j+ e; P

( W1 Z. x. i. l) I' ^7 t6 Y, i// comp为applet上的任意一个组件  
' w- K# {# a  Y* D: S- ?; w
. f+ c4 D! X* E8 W, k  t....  4 V8 {, b7 ]& {" j, H

, ]) s4 i+ P3 Q4 q; q( u
0 z  z* U8 y3 p% X5 I  w: L" M
2 f2 h4 q: A& U0 M( O, Ipublic void getParentWindow(Component compOnApplet,String title){  9 E& {/ _2 j* L* F- L

; [5 q) T) C( ?9 ?" E) V0 o  T/ aContainer c = compOnApplet.getParent();  1 X! F' H; W- L  I6 D3 h+ R4 a

$ R/ n1 R& s. Q! h3 M0 _while (c != null) {  # W" t1 f( Y' g7 b) s9 I& z

5 r+ {; G, s  J- Q3 R! Y6 F. Xif (c instanceof Frame)  
4 x) Q0 o4 I$ y5 N/ |+ }& \$ r( g/ b
return (Frame) c;  
6 C! I; U+ f3 Q; k; C) p+ w
) x7 `2 N  N' @; F  n* Fc = c.getParent();  
5 k: S7 B$ C9 A; g$ P. `9 y* H, a
5 r& g; F6 G3 N! _. S# c3 ]% ^}  
5 L. M0 A: G1 N) X$ z. E* ^
2 j$ R: B' T5 B( i. Kreturn null;  
+ `# y7 r8 H1 ?5 ]' [" ~6 Z  e  [
}  
/ H( \9 k0 J0 j
" i2 F, d' ^7 {0 g问: 在Java applet中如何显示另外一个HTML页面?  
% F' |" Z- ~) n9 Y0 {  i; @" q1 a( {- \0 p% b5 |
答:  
3 J6 s. L* k$ o通过java.applet.Applet.getAppletContext()方法可以获得与该applet相关的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的浏览器显示另外一个网页.    a  l6 f% s" e9 `8 Y! y
& u0 K# U9 V0 }% S. f4 O
问:  
2 Z8 q0 g! u, g/ X, N用JDK实现的签名applet,可否在Netscape或IE中运行?  
2 `* X' ^0 O; i6 Z6 ]! Q6 W1 k! |3 P) N
答:    g! k$ t8 l/ A& {% y
用JDK实现的签名applet,不可以在Netscape或IE中运行,但是可以在Hotjava浏览器中运行.    Y! S6 r8 g/ m$ Y$ u4 h- y+ d
$ Z5 w& A% t5 H' M7 U0 b% D
不同的浏览器提供了不同的签名applet机制,如Netscape提供了zigbert工具和 Capability API, 而IE则需要使用CAB文件. 但是,无论是Netscape工具产生的 签名applet,还是用IE产生的签名applet,都不可以在其它的浏览器中运行.  9 n9 L8 T& I* r& {) _3 n
! z$ S" D6 G+ }% j- Q
如果要使JDK产生的签名applet能够在Netscape或IE中运行,解决方法是在 Netscape或IE中安装Java Plugin,则用JDK实现的签名applet就可以在这两种 浏览器中运行.  
/ R% g3 q5 K. g7 L& O& M. J: @+ d! d( j- e9 w: N
问:  
' e/ @! k7 r# r' [3 k用JNI技术可以从Java应用中调用C程序库,但是如何使该C程序库可以调用另外的C程序库?  
6 c6 M9 m( f- c0 k0 D6 E& b6 s  y
) S5 T3 c! _( N7 G答:  
8 k, k* [6 _$ d% K如果一个被Java调用的C程序库C1仍需要调用另外一个C程序库C2,那么在编译C1的时候应当联接程序库C2,步骤如下(Solaris平台):  / @( J" C) Y" r2 m0 D0 @
编写调用C库的Java文件,并编译.  
' m" t  z) m. K0 D4 l5 ijavac java文件名    {' ^1 [2 T* H2 I8 y# _: p

# Z1 |* F- {0 J" @
' d! l% y- p( W) U' a产生C程序头文件  
5 t& |, q' n4 H& }javah -jni java文件名(不带后缀.java)  ' u2 i* D) X4 a7 S' `* ]9 G* w! H

6 ]  w/ ^, ~  h0 m
# F! s, T7 z( d" W* U编写被Java调用的C程序C1.c,以及被C1调用的C2.c,并编译.  & r$ t3 z2 y+ B+ {2 g/ i
cc -G -Iinclude路径名 C2.c -o libC2.so  # m% J: w8 V9 [! M6 A) u4 M
cc -G -Iinclude路径名 -lC2 C1.c -o libC1.so  
! M/ h3 N6 e* T5 t1 g% G2 a  X# p+ B* S. M

& e- L! Y1 p3 H8 J6 d设置环境变量  % U4 k9 I; T) S/ C# s
setenv LD_LIBRARY_PATH libC1.so,libC2.so所在路径  7 c/ B: H7 i& s* k$ c% n  {* Z) Y
{LD_LIBRARY_PATH}  8 R5 v3 h% G$ f- Q! n3 i2 }

2 F* q: h- m7 p$ F+ L5 k: b3 _; }4 j: Y8 l! A( F! ?+ Y# Y
运行java应用  
1 E/ ?! A1 _9 X# o8 h8 c4 Q: Q: o$ @+ j; g0 r8 w8 S

& j, a( r) }  C- f- ^& [% z问:  
0 [7 T4 G, F1 p8 Z; _9 Q, g8 S在Java语言中,如何列出PC机文件系统中的所有驱动器名?  
! [: o% |/ z5 _- d9 e
* P. x  B* a9 m% M8 {3 f5 T答:  ' C. y2 E% Z  I, f# o0 f7 z
在Java 2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.  8 n4 J* {4 T: p) c

, m/ q8 J: {3 y5 e3 c- X7 E问:  & g1 E4 h+ @5 @/ t8 \, T
为什么Runtime.exec("ls")没有任何输出?  
: v4 |5 D4 B. o/ S5 ]% L. ^% V7 ?
+ n( k  Q4 d" c答:  
  I% ^4 ~" e6 m+ x1 I调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息. 由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向 子进程输入数据或获取子进程的输出. 所以正确执行Runtime.exec("ls")的例程如下:  4 t8 \: x, }6 l6 t1 H7 M

, f4 b) @2 ]/ s. ?- c' N- \) U/ ]/ I5 c1 ?+ @; _0 ?# G
try  - A1 h# q# z& c& g; q0 R
! D4 y9 C8 @" E' ]
{  
: f, y1 n! L1 {0 x5 A, Y- ]/ T! ~% n
process = Runtime.getRuntime().exec (command);  8 q2 W& k, A# N8 [3 H
; s: E9 Z& j( p$ C) V7 B- ^3 J
InputStreamReader ir=newInputStreamReader(process.getInputStream());  
2 q  N6 q9 ?( Z: L! `6 ]
) X1 G/ Z$ {! D, t& C+ s* c0 yLineNumberReader input = new LineNumberReader (ir);  ' `, f/ t9 _; u! @  m

5 ?! V6 X8 j2 ~+ b- ], y2 F$ FString line;  
8 s7 x0 X3 x! W/ c
/ _) w7 ^+ l/ q& x: jwhile ((line = input.readLine ()) != null)  
2 @" E+ k- K/ `( q% n. q% C0 y5 A5 l; \4 V+ E" J
System.out.println(line);  
  ?( S, k/ S2 L# Q) \5 z% h1 B
+ E3 W7 s5 G% n3 S}  / B* }6 x% t' b

5 X2 F1 w' D1 K0 P! t3 o- ycatch (java.io.IOException e){  6 r/ R& U) P( R3 A! I2 Q) w
, P6 ?. _+ G* Q6 X8 X. Z" N" z
System.err.println ("IOException " + e.getMessage());  
2 }8 N3 L0 D, Y$ _9 c) c' H
; Z& N' v, |$ x4 H}  ; p3 T4 _8 j9 J( E7 p% ~. v
! {/ T- d) e. I
0 s8 I, H) E$ w4 j% L- U0 m) `
问:  : N0 ~7 @+ S' N# F# S
如何产生签名applet,以使applet能够访问本地资源?  
/ K6 C0 T: z9 H) r4 S, u3 i
* G* d3 p# W# f8 U5 n# T答:  
3 c. s0 q5 G2 Q9 Q, r. |在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料 请参考: http://java.sun.com/security/usingJavakey.html而java 2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java 2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:  & ?9 W- {8 b2 z+ D2 P! K
! s  j* D7 i# E3 q

  T) ~8 W. A1 p% I- c//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中  6 p: [2 a, n3 F# L! C( i$ a9 _' e: x
0 n9 a; B2 F# j8 D+ L8 b: Q( _( g
keytool -genkey -alias joe -keypass sign12 -keystore joestore  ( p6 z% {  z: o8 Y
% C4 ?! x0 w( X" Y& m' n( z" F
//将SignedApplet.class及相关文件打包成jar文件  
* N( {; \/ w% k- l! m! s) j; \1 K( ^8 g( y3 E
jar cvf SignedAppletDemo.jar  
9 ?" c3 X- U8 J0 Q7 U9 w- P6 d6 M! P" E
//利用keytool生成的自签名的证书产生签名applet(jar文件)  4 R: U) \1 y! K+ y0 e, I

' y  a' d- @4 Ijarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe  3 B! i; Z- C& Z9 G9 l+ t( g

" J% Z, a0 d! V//将自签名证书从keystore中输出到文件  + a" }7 e0 k4 @% H
6 I" G7 O: \& Y# C  U: D
keytool -export -keystore joestore -alias joe -file joe.cer  ) {# I+ Z8 b8 c" S
7 d3 @* s! g9 J" m0 K
* l/ q7 C/ E6 S: ~
3 P: q, ]  `5 \4 s/ O) n
而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行  
# p' s; U- g1 a5 V' Z9 L" X2 B9 k0 b$ o( O
Joe编写的签名applet:  " H- _# G; I7 h2 [: K- n: i9 l
* P2 \4 h) v; k1 P1 {
//得到Joe的证书并将之读入到密钥库中susanstore中  ) g! f5 u/ D! ]# C5 l
, ~7 ?. C2 a  G+ D
keytool -import -alias joe -file joe.cer -keystore susanstore  
' x! n  A' {( |. F! j% l
0 @  V7 a3 y4 |* Q% j//运行policytool产生满足Susan要求的policy文件  
" z) `1 x' k+ g! S! J  ]7 S" r' C' Z7 j/ P; D% a0 z
policytool  
* l# A! D: r1 |( N( b2 G* f0 ^: a- @6 `
//用appletviewer运行之,或在浏览器中安装java plugin来运行之.  
$ Y# b% M4 p4 i$ X/ l. e" v$ A# X. E: e& L' ^$ m9 V' [5 ~8 o
; J6 f6 Z/ F0 t7 U/ h9 X

, j1 u' J  s2 x% |关于签名applet在Java Plugin中的部署请参考以下网页:  ' a' Z  s8 V. T9 V4 |  A
; e0 G, N1 v% s' ]* z4 \
http://java.sun.com/security/signExample12/  
. H. Y0 [" Z2 i4 I0 ?5 U  _' f) ^: L5 i: z+ m/ v1 h9 e: g+ \, M& r

" V- x" Y$ j' A  P5 `& Y+ e- p+ q/ \* t0 @# f( t
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以  % a9 y$ m: m, A/ A. h
0 n: I' l: A2 {$ o) q; C
使用keytool -certreq向商业CA中心申请电子证书.  
5 s# U9 a& v- B" ?) {3 R( `) J" Z4 @) ^6 X9 H; s: \9 U
  p. v. |" q$ z  p" L- R/ q; B
' y4 y6 T0 ^7 \. h- P. s; ^- ~  g
7 F8 x6 ~1 w. ]8 s. {
问:  
. r0 g6 n' S7 i, n1 F8 z% Y( o( L3 S若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?  " c1 `7 q$ X. F0 E
0 q( f9 d3 L4 m5 R
答:  5 r1 I! j% G0 W& X9 W) ~/ g4 Y
使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.  4 f! Z# m/ y9 t- H
$ b' M7 q9 M( r3 F
问:  
4 A1 M) `8 u5 `. x8 R+ b对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?  6 T- ~2 a- d! r8 V0 I# ?
* |* H" r$ k% T, X* O: H
答:  9 N* \: _+ s) y# }/ X6 k! B8 X
目前,没有直接的方法可以将对象写入到随机存取文件中.  
# Q, p/ {4 G4 |但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误. 例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.    D7 p* F! w* f* p7 c

( o1 [: p- F- l问:  , b( r2 u9 u- ]+ v
运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?  
/ b! n6 p& R) J5 k6 B/ B
+ u9 G6 k( O3 I, u答:  
; P1 R0 ?4 K1 @7 u; v* p可以. java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(int port)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于获取名字服务.  ) m1 S6 G" W0 _2 P1 \. @* Y
7 |' J. r/ a6 z! h: _, h1 O# o/ F$ `
问:  
: B9 \8 ~, r$ p8 e4 c- T5 I: @使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?  - a/ _1 h/ A3 H+ T& t5 ?! B* y* B

: d0 H  H, e7 U- T+ I& l% x+ t答:  # y$ I! m0 E* F/ t9 g- j9 H
使用如下方法可以获得PrintJob的实例用于控制打印操作:  
/ m# [; [8 w/ _# r( Z
$ d* `/ o6 A1 K3 `! q4 D; D! C+ ?% V4 I
Toolkit.getPrintJob(Frame f, String jobtitle, Properties prop)  
, v; [$ F) ]6 A" E$ R8 i0 t4 }* k9 O% I2 d& D; d
那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:  ( Z+ n: T1 u4 r0 k; m, o. W4 O
4 ?! J% x4 |8 D1 c7 x
awt.print.destination: 可以是"printer"或"file"  
( U1 d1 n( ~" g' J8 U
. D& T: z* g" Iawt.print.printer: 打印机名  
0 T2 h* w' H" N7 b! b0 f% z7 L+ R: R5 p; B. P
awt.print.fileName: 打印文件名  & V9 D% j, i: z1 s: @  l3 m, P

5 u) k; p$ c5 v9 L  E# Qawt.print.numCopies: 打印份数  
: O: |0 V: r" H9 g; b: q4 M: V
1 i0 `6 i% x1 U& s; E, r- @awt.print.options: 打印命令的打印选项  * X: R+ J; D2 A* |2 @$ R) M9 D
3 c) J% v8 F; X4 {8 q& v6 @9 G
awt.print.orientation: 打印方向,可以是"portrait"或"landscape"  ! ]9 O4 g1 `! `5 U$ T) P

0 h, ?+ |) m! G* e8 q# t" iawt.print.paperSize: 纸张大小,可以是"letter","legal","executive"或"a4"  . I, ^( {$ j# ~- [) K1 q, u

0 d& r3 j' ~/ L0 R* H' j
( t& n+ }. ~, z$ g7 m" z; d! _( O+ c/ \0 f2 p  o5 ?( W

) d. w& N$ u5 y2 I3 U; C$ H- U* w1 u

  V+ N* M1 s7 W8 _! |6 h问:  5 {6 m& @: d. A* F, G
在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?  
' C0 F4 @. R# _, I0 S" B( l; T1 O* T  w( a% ]+ q
答:  * ~& l: x( {/ |! i
Thread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.  ; @* l. q6 k* ?
7 q+ F) g+ @6 o
因此,在Java 2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.  
. I9 b8 c  f9 _# ?) y1 o( I
$ o. S1 {! I& e; f+ O问:  
6 h" n0 e2 n% _' C: u使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?  % J6 x* R1 M+ U! k9 o
# B5 {" G8 S" R
答:  
  f2 o3 r1 N/ a' i7 R4 |在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java 2中,ResultSet类增加了如下方法支持数据指针的移动,包括:  
$ X7 |% m! ^2 `; v' ?) `, f/ v" I- a1 a  V

0 E3 n, J: f, |ResultSet.first():将数据指针移到结果集的第一行  
; r) p, S% k; i7 o5 \
3 l& E2 s$ `  jResultSet.last(): 将数据指针移到结果集的最后一行  3 s3 S1 X, `) M2 x  s9 ^8 k/ `! S
9 _- f7 |" r  r+ Q! }3 T* J
ResultSet.previous(): 将数据指针上移一行  
! ]3 N! F) U$ }. R1 A" p3 H& W9 ~! W+ Z7 M9 U; F
& p! l% ^; Y6 O1 [' h
以上的方法定义在JDBC2.0的规范中,所有支持JDBC 2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC 2.0 .  
$ h3 g8 T& g6 v9 p' ~
7 L( }. g) I( a! u/ t3 E9 b& N7 q. x- K( {
问:  
: P& @/ r3 V! l7 X; i哪几种Web Server支持Servlet?如何使IIS支持Servlet?  
% x# j3 b: F2 Q5 V
4 m" a# _& [! G- m答:  + u& d( Z0 ~( Y
目前,支持Servlet的服务器端产品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.  ) }& H/ G. c0 u5 `( Z8 K$ V) A. W

! w% d% s8 n* E# D. Z此外,一些第三方厂商也开发了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能够运行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.  4 X  l/ }0 L  }6 Y/ p

; ^1 D( y. }+ Q1 f! B4 R+ V问:  ) @3 E9 ]0 W/ I; E
如何在Java应用中将图像存储到图像文件中?  
( F1 Y4 ], U8 b& s8 j: H$ n( u, I) [% Z, g/ `% `% ?
答:  
- q5 p& X! w) dJava Advanced Imaging API(包含在Java Media API中)允许在Java应用中执行复杂的,高性能的图像处理.JAI API提供了存储图像的能力.目前,JAI API支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:  
1 H! r& g6 S- I- G, F7 X* E/ Q$ ?4 I
" ?1 c. M) A+ [2 j
OutputStream os = new FileOutputStream(fileToWriteTo);  . k+ o$ ~9 \7 J$ N# M

' L" |3 Q4 Z/ C  A2 \BMPEncodeParam param = new BMPEncodeParam();  
+ m) Y, c. U. h
+ L# l# P: r1 b1 yImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);  
# R5 z6 l* f5 _9 i9 r9 O; t8 }- }5 d5 j! w
enc.encode(img);  
9 J0 Q8 s7 s5 p2 ?- L* h/ z7 Y. l5 K; B  O' Q/ f
os.close();  
! |5 I3 W8 T& S% J5 P
' v9 l: }8 `1 }& [8 V有关存储图像文件的编程指南请参考以下网页:  
% a& B; ]  N6 x$ M, b1 ~. F; ?. ^, @# u
http://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/  
2 i3 w1 b9 f8 {1 h
! T# }2 T% V. N. z% z% X: o7 j
8 y0 z( v7 A3 x' w& d/ \8 w. H5 D7 S, `' k

) ?( i& N$ x' f+ z# J; Q/ i. N问:  9 U0 H( V' Z% h" P0 I5 J3 i! ?6 |
如何用Java语言向串口读写数据? font>  . c3 u! Y9 |6 M- t7 J! C

; u* ^- ]4 c3 X, l! R  x* e& l答:  9 \" h" E2 W# ^5 l
Sun公司的Java Communication API2.0可用于读写串口,它支持RS232串口和IEEE 1284 并口,提供了一种与平台无关的串/并口通信机制.  
& Y! `* J/ t/ e: N* d0 D9 @
' C: t" E8 u$ C; g详细文档,请访问:<a href="http://java.sun.com/products/javacomm/" target="_blank" >http://java.sun.com/products/javacomm/</A>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
如果我没给你翅膀,你要学会用理想去飞翔!!!
deven1985 实名认证       

23

主题

3

听众

2433

积分

智慧的蓝色小毛驴

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

    [LV.6]常住居民II

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

    新人进步奖

    回复

    使用道具 举报

    wl820609        

    1

    主题

    3

    听众

    23

    积分

    升级  18.95%

    该用户从未签到

    新人进步奖

    回复

    使用道具 举报

    wangyu249        

    1

    主题

    3

    听众

    54

    积分

    升级  51.58%

    该用户从未签到

    新人进步奖

    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2025-8-2 07:18 , Processed in 0.722962 second(s), 71 queries .

    回顶部