QQ登录

只需要一步,快速开始

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

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

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

206

主题

2

听众

882

积分

升级  70.5%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-3-31 01:31 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
问: 如何设置Java 2(JDK1.2)的环境变量?  8 s; g, J8 J) }7 z6 h! @
" _) [1 U6 I+ S
答: Java 2安装后,需要设置PATH和JAVA_HOME环境变量.与JDK1.1不同的是:设置好JAVA_HOME环境变量后,JVM将自动搜索系统类库以及用户的当前路径.  % v& R1 y: ~& j5 ~' z7 F
Java 2环境变量的设置如下例所示:  
. d' |; F: I$ A: TSolaris平台: setenv JAVA_HOME Java2的安装路径  
6 k- J5 k0 X* m- l3 \  |  U% R5 dsetenv PATH $JAVA_HOME/bin{PATH}  ) A8 r. j: H3 t+ c# g
Windows平台: set JAVA_HOME=Java2的安装路径  
4 z- g' K* ~7 ?) L* wset PATH=$JAVA_HOMEbin;%PATH%  ' S' X- K, P3 J, O1 S1 e& H

* ^& ?! s- p. b+ I" b0 Q问: 哪些Java集成开发工具支持Java 2?  6 G& I* U* v& L% q8 d9 m
) {, X* M9 b! m5 `4 X
答: 目前流行的Java集成开发环境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.  5 E/ G2 z% B8 m& h+ w9 X' t4 C

: C' h% R* c! Z问: 如果在Netscape或IE浏览器中运行Java applet时出现了错误,如何确定错误范围?  ) ~9 j1 B9 {! i# j& ]
! W8 `* z8 n5 M& j- ^: l
答: 当java applet在浏览器中运行时,使用的是浏览器本身的缺省JVM.而不同浏览器对JDK的支持程度也不尽相同. 因此,在Netscape或IE浏览器中运行Java applet出现了错误,建议使用JDK提供的工具appletviewer或Sun公司的Hotjava浏览器来测试该applet,以确定错误的产生是与浏览器相关.  
$ P/ H- q9 I3 F) {    如果applet在appletviewer或Hotjava中运行一切正常,则错误的产生是由于浏览 器不完全兼容JDK而引起的. 此时,解决方法可以是使用Hotjava浏览器或者安装 Sun公司的Java Plugin.  ) o0 ~8 N1 M% Q# M! d
    如果applet在Hotjava浏览器或appletviewer中运行即发生错误,则应当根据错误 提示检查applet程序.  
+ x; K$ l! Q& x: }. K2 v1 q# Q: E" L2 S# j! N7 x2 L5 g* t* |
问: 当用JDBC向数据库中插入数据或从数据库中提取数据时,为何有时中文字符会显示为乱码?  
# u! G6 ~8 e* l9 v- h% c
3 S" R, o0 j: W* {& c答: 这个问题的实现通常与各个JDBC driver的实现有关. 目前大多数JDBC driver采用本地编码格式来传输中文字符,例如中文字符"0x4175"会被转成"0x41"和"0x75"进行传输. 因此我们需要对JDBC driver返回的字符以及要发给JDBC driver的字符进行转换.  7 q+ R9 V6 f7 L% F0 ]* x

, b' f4 ^' s1 Y  z9 M当用JDBC driver向数据库中插入数据时,需要先将Unicode转成native code; 当 JDBC driver从数据库中查询数据时,则需要将native code转换成Unicode. 下面给出了这两种转换的实现:  
/ O- V5 w9 w& N& y+ |4 U
7 k* h/ L: Y' Q9 c" }
$ U" p$ b& B0 P6 GString native2Unicode(String s) {  5 I' d( b+ Z/ p- B& y

" b) g# E2 m% g5 J; q8 j$ M9 F2 gif (s == null || s.length() == 0) {  / c! B# C2 V+ s

+ N+ D2 H( h3 e$ Z5 vreturn null;  
9 N; F1 k* O" y4 w
! K/ \# [( S: v0 P}  ) K9 W1 ?8 D2 Q4 }0 }! n

# j0 }: A( S& K% pbyte[] buffer = new byte[s.length()];  
$ h/ S' ?# ?. l% d
" D& C$ v& z0 D& b" |for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {  ) V4 R: N* F4 l" Z$ M

6 }6 s! k' a* m3 ac = s.charAt(i);  ( V) s% d! [; x  _: ?

, E$ N8 C  h7 ^# hbyte []buf = (""+c).getBytes();  
6 A. z: }; t8 c$ U& m5 `% X3 `
# z1 }% M/ o9 {" k4 hbuffer[j++] = (char)buf[0];  ; G& s8 l6 R( b' S  U0 R
, b+ U2 t  @, {9 f
buffer[j++] = (char)buf[1];  
! F3 [! [+ L  R# h5 ~( i- H& ~
' e  ^& H4 J! u5 M8 C+ s# J}  : C# b5 `" m3 k# ~; W# n
- q3 X# q: i6 ^6 p: K
else {  , e4 N( y5 m. G4 g7 b' Y0 z" @
0 i6 l0 w+ Y$ u
buffer[j++] = s.charAt(i);  
3 ~/ W+ z1 v0 x$ Z3 b7 A$ J6 f3 C! h" d& j# m* w
}  . c9 [3 r  A: p8 F0 t4 e

6 z: ?2 A9 V; K7 E3 Q}  
- V5 m) J( F, D; M3 [9 h$ N! y; \& W$ o# W, f
return new String(buffer, 0, j);  
, l8 ?2 v2 C. [2 h' n3 C: J4 E; Q3 V) i: l  n1 t6 E
}    `, x5 K8 [8 b0 E: |5 C
0 b0 m& E" g! b
除使用以上两个方法之外,有些JDBC driver如果对jdbc driver Manager设置了正确 的字符集属性,以上2个方法就不需要了.  ( [0 W0 I# Y/ M; s+ p% y
& y! b1 J5 P2 ]) p- a; b$ t$ D3 f
! A4 x4 \7 c7 N+ D& v
问:  
- E0 x; o: B' K/ w* S; H1 W当用Servlet来处理http请求并产生返回的HTML页面时,如何使HTML页面中的中文字符能够正常显示?  
' O& T$ T- Q% N% N
* z0 N% Y' b) e) O9 b答:  / J: q0 _+ p" m+ H( F
javax.servlet.http.HttpResponse类用于产生返回页面.通过HttpResponse定义的方法getOutputStream()可以获得ServletOutputStream的实例,这样用户就可以利用ServletOutputStream.write方法向输出流中写入返回页面的内容. 但是ServletOutputStream使用的是缺省的编码方式,如果要使返回页面中的中文字 符能够正常显示,最好显示地指定所用的字符编码方式. 通常需要构造一个 OutputStreamWriter , 例程如下:  4 F+ V$ s. x- g0 j
% c. Z+ g) N6 I; z; u+ S7 Q
' w0 z1 O+ i* Q) N9 l: l$ _
public void doGet (HttpServletRequest req, HttpServletResponse res)  & b6 K- ~$ M" O3 y' X8 w4 w! O
4 c0 ^# \5 {0 S4 B' c# S9 ~
throws ServletException, IOException  
% |0 i1 }2 M+ @) ]: Q. w) M0 J7 Z0 H+ A
{  
  d3 ]8 G; F" h+ B; _2 ^+ a- P8 t7 c( y- q8 u0 y* ~. U" k
res.setContentType("text/html");  
- a( G) l7 ^0 ]' I% G+ ]. r7 z& U$ l5 w/ j! W
ServletOutputStream out = res.getOutputStream();  ( k& ]/ v4 z! Z' Y
( G5 R, r5 y5 S) ~9 d
OutputStreamWriter ow = new OutputStreamWriter(out,"GB2312");  
4 z% q- X8 g& M" V
- a, J1 ~$ x; z+ F: Eow.write("这是测试");  . z( a* W! o) [/ ~9 o

: m! H; O1 n# I+ `; z* }ow.flush();  
1 f7 ~3 I  @+ \" A* P5 Y% D* k5 A% i4 P. x+ v( l; x
ow.close();  / p4 Q$ K5 W" Y" j+ N+ E
( ^, u3 @  f; C. d
}  
0 N5 a- q. j3 Q5 A
( {! o- T4 n! Z* F. d" y& ]' @* y
# {: ~& Q6 {' f3 P. f4 _问:  & |! }$ L8 F. ]5 n+ Z: n# t
如何设置Java WebServer的CLASSPATH,以包含用户的class文件?  ' G# V1 y% G, X' F2 `0 _8 B' ^

0 X* m: @% J8 k% R1 c答:  
' h' h- M& c' Q1 _) e# \有两种方法可以设置Java WebServer的CLASSPATH环境变量,以使用户编写的Servlet能够调用用户的class文件.  6 J7 q9 X$ I/ \" H4 n
将用户的class文件放到 JavaWebServer_Dir/classes目录下,在Java WebServer 启动时,classes目录被自动加入到CLASSPATH环境变量中了.  
; V' C# S1 z0 W修改httpd.nojre文件,将用户class文件所在的路径名加到CLASSPATH环境变量中.  ; w8 Y( T- h. ?

( f) O3 r& q2 S* S- ~+ n, S( L# ]: K& Q& N& a5 Q2 I5 V
问:  9 Q: S4 L6 I2 C  n& i
为什么在Windows平台上用Naming.lookup来获取远程RMI对象时会很慢?    R4 M$ \; M% p, e* ]8 r

$ l% C$ q9 D3 p$ B答:  5 F3 b3 {2 U* K$ @4 n0 \- l7 K2 h
机器的网络设置不正确很可能会引起该问题的发生.  ) S; \# r5 u; X" v$ I
RMI使用了Java网络类,特别是java.net.InetAddress类,它将查询TCP/IP的主机名, 包括IP地址到主机名的映射和主机名到IP地址的映射.在Windows平台,这种查询功能 是由本地的Windows Socket库来实现的. 因此延时是发生在Windows库中,而非RMI中.  . j' ~" Q* D( p) c6 ~& r& S, O: n
2 v/ |' b# ]4 l/ j" D
如果你的机器设置成使用DNS,问题通常是DNS服务器查不到主机名,你所发现的延时 是DNS查询的延时. 请尝试将RMI通信中涉及到的所有主机名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:  
, F5 O; y2 Z3 Z& T" c5 \) h% D7 }# ?1 r/ h
IP地址 主机名  9 ^) ^3 g) x9 p" K9 f

2 g/ O4 ]: I. V; X9 Y, a* P1 R如此设置应当可以明显地减少查询所花的时间.  
$ q! e5 d) ~" u1 m! J
! K3 u7 P& A- o0 h( }( U问: 编写Java application时,如何设置proxy的信息,以便访问外部网站?  * n: t6 F% |) x2 m& E

1 o8 T5 x9 |; j3 N! ?答:  
0 G1 `8 z2 U6 i: w" X, F若在java application中访问外部网站,首先应设置proxy信息,样例代码如下:  
2 o( C' }# H* W. [
8 |: ~! ^6 _, T/ }* _( K" h. H4 _; W: F
import java.util.properties;  * U2 H( u% R6 ~0 F8 `/ f: m6 j
0 W# H# Q7 K) b# q
.....  - C2 U2 A, t- [6 P% }  P
7 x  r/ V9 ]3 \2 I6 U
Properties sys = System.getProperties();  
! a% f2 ^+ }% V: \  @8 W8 \  D& B: S- U/ n
sys.put("proxySet","true");  % G% ]* T5 X2 B  x* O0 i5 m
% T7 v! k& q9 @7 v1 m
sys.put("proxyHost","myHTTP.proxyserver.com");  
7 x4 s: F# `$ i6 P' N6 g( {/ |+ T9 V3 F5 U
sys.put("proxyPort","80");  * K3 k- g2 a6 a6 `( {
) D) R! p* `4 c# _
System.setProperties(sys);  ( M; @' i3 G7 U

- q1 C" P& Y# W& n$ ^, t) H
, E! L( B) g6 ~4 g! m
9 v7 S$ Y$ ~# \" U: ou = new URL(website);  ! Q' Z! s6 N( ^6 i" S* @7 u5 t
* D! l" J# d( T: J
connect = (HttpURLConnection)u.openConnection();  
% o+ X9 J! m! M. K" `: q  \1 }# z
; u0 b9 {5 K/ V8 ~$ C.....  7 S# K% p3 c7 n% R! `. a

9 U! ]0 [% @& c) {" C, x问: Swing组件JList的列表数据修改了,如何通知JList改变显示?  4 D' [3 A: k- o" R% q% h
6 A0 j! e* U2 M; ~: N& U
答:  , u% U; ?% X' h' z5 u: `, V! f9 r
JList组件有一个单独的显示模式ListModel来表示JList的显示数据.  
6 p; A1 U3 O$ `* P+ KJList创建以后,JList数据元素的值及数据元素的数量可以动态地改变.  : X, o0 J& ~5 x# Q: `
JList在它的数据模式ListModel中观察数据的改变.因此,一个ListModel 的正确实现应当在每次数据发生改变时,通知事件的监听者.  
, R5 X& }* J! v+ |  ~- f当使用构造函数JList(Object[])创建一个JList的实例时,系统将自动 创建一个DefaultListModel的实例来存储JList的显示数据, 可以调用 DefaultListModel中定义的简便方法来动态地修改JList的数据,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改数据的同时,将通知JList关于数据的改变.  " Z2 b4 j* \3 ~

" |" a# V  T( S; H5 a问:  
4 O- c( n) ?- @  a' g1 W& }! r9 x' D在Java applet中如何实现一个模式对话框?  
: r) B1 @. [( {$ m
7 i" ]: P1 b& _; N) @. Q答:  5 J/ K( K# Z% Z+ `, q9 s- E
在Java applet中实现模式对话框的关键就是在创建一个对话框的时候 要为该对话框指定一个正确的父窗口.因为Applet是Panel类的子类,不 可以作为对话框的父窗口,所以首先要获得applet所在的窗口,作为模式 对话框的父窗口. 样例代码如下:  * f& L/ l9 h: [' |8 S" n+ L

7 |9 V8 F- a/ Z3 u# B3 P7 U
, G$ {3 p$ a% v4 j3 g& o: D.....  / }. q' [+ ?6 R  }

( G1 C9 {. O3 {Dialog d = new Dialog( getParentWindow(comp),title);  7 z0 j% e" o5 c' R
% V: c+ s9 E3 `6 `! B) |) J
// comp为applet上的任意一个组件  
# O# v3 H/ }% e
- s) m2 I; Y7 O3 E% W....  
; {) P. T. g, R% v* }+ Y
5 R) ?% S* L0 {. n
+ ]8 u4 s2 A0 @$ U0 A+ a- V/ J) K& M1 ^# a  d2 v3 x
public void getParentWindow(Component compOnApplet,String title){    i, U4 S# Z- N6 u0 S2 W
: @0 [, K" c% d( w! v
Container c = compOnApplet.getParent();  
% {! I2 f7 r. Y! j+ X& Y( R3 q2 {
while (c != null) {  6 [- s8 |4 u# Y+ G; L" a' ?

8 t0 _+ Y6 z* W: bif (c instanceof Frame)  5 t1 ~- Q# q0 R* g5 A
) E4 \0 V& ^' i
return (Frame) c;  . X. u4 n) v: a' \- P3 w2 ~; B

: _( C$ N( n- o5 L# Ec = c.getParent();  ( M! A5 `/ i7 K
. G- G- X5 j5 R" z4 L4 `  |
}  7 t, [; e# a) ^- r  K
# Q/ p! q9 v& F5 F% `
return null;  
5 S+ D2 ~% Q* F
3 `% J2 y9 B  D7 G6 `# [4 A}  
1 S3 ^0 z7 ~$ t9 R& ]2 R6 b( W0 M
8 g1 |+ n# v& `: v. d问: 在Java applet中如何显示另外一个HTML页面?  8 E9 I6 Y  a3 }+ `( `4 e9 X# S

  S+ c7 J/ G& T答:  2 l# e, D! }7 f) e
通过java.applet.Applet.getAppletContext()方法可以获得与该applet相关的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的浏览器显示另外一个网页.  
' \% d2 U  g, r* u( V
2 F& l) O7 N2 Z# M# k% ~问:  
9 B7 x; S" J. X% ~5 o; F用JDK实现的签名applet,可否在Netscape或IE中运行?  
: p  j' A% g4 B1 m; _" l; S1 I4 r, B/ F: P0 h4 _! h
答:  
4 Y* ]5 X. h. a  q* A) T用JDK实现的签名applet,不可以在Netscape或IE中运行,但是可以在Hotjava浏览器中运行.  ' C0 ]- ?! R# t7 O, E
! N% H4 t  k1 G$ c& c
不同的浏览器提供了不同的签名applet机制,如Netscape提供了zigbert工具和 Capability API, 而IE则需要使用CAB文件. 但是,无论是Netscape工具产生的 签名applet,还是用IE产生的签名applet,都不可以在其它的浏览器中运行.  
9 D% T% t; v- T) s, V# z  z: `* n! O$ l7 ]  l3 B; Q
如果要使JDK产生的签名applet能够在Netscape或IE中运行,解决方法是在 Netscape或IE中安装Java Plugin,则用JDK实现的签名applet就可以在这两种 浏览器中运行.  
3 X. n8 |, N1 Y
1 y: ~# A) j, j  Q# D! O问:  " A* _, ~4 a8 g  s- k
用JNI技术可以从Java应用中调用C程序库,但是如何使该C程序库可以调用另外的C程序库?  & j7 F% ]5 b; t/ Z4 O

8 l2 h8 e5 Q+ l, i, k" r答:  1 D, o! T5 B0 L0 N8 F
如果一个被Java调用的C程序库C1仍需要调用另外一个C程序库C2,那么在编译C1的时候应当联接程序库C2,步骤如下(Solaris平台):  
0 T. `8 W, ?7 J! E9 @9 ?* k编写调用C库的Java文件,并编译.  ! o! n! b2 |9 I# B- E, x
javac java文件名  
' W0 T* p* Y& k
" z# T! h, r& o, p
7 g9 L  ]4 Q) a$ j+ s产生C程序头文件  5 j* e; j4 @% I
javah -jni java文件名(不带后缀.java)  2 b! E' w% \( e2 u; s+ q

' q/ e0 i/ p, U2 s1 z
2 m3 P4 ~! W. w2 |6 \' S, O0 J编写被Java调用的C程序C1.c,以及被C1调用的C2.c,并编译.  8 v/ d) G& F* W0 ]9 p5 w2 O
cc -G -Iinclude路径名 C2.c -o libC2.so  
& f8 }) \" V; icc -G -Iinclude路径名 -lC2 C1.c -o libC1.so  6 r- q; p! i. V- G- q( s( ^

# W$ l, `5 }$ D- l$ F4 x% h
/ _* f! Q3 b- r; S+ l4 o6 }设置环境变量  
3 e  t$ o. C4 z6 Y" ~4 ~setenv LD_LIBRARY_PATH libC1.so,libC2.so所在路径  
$ r; K7 }9 k& h' ?' i! m0 L{LD_LIBRARY_PATH}  $ @# j. q- B: K5 u

- Y( x/ M$ o% e: ?4 ^, S) Z5 c+ W/ V3 s7 C9 P2 [
运行java应用  
9 V2 F2 b9 J# j& e9 g7 j7 D0 a6 J% L* T7 o' ^7 Y3 c: l. J
, k4 [* N1 \7 s$ L* g, o* i
问:  % P; d% U) ^8 u8 x
在Java语言中,如何列出PC机文件系统中的所有驱动器名?  5 [, S' O0 |) V
5 F6 k- ]9 x+ h8 g0 B& m/ O4 E  `
答:  
/ d; J; i7 u' _5 N8 p  O在Java 2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.  7 v8 L$ ~* D4 X( d, Q% [6 D! b

1 o) _' `% p% |/ }( U- Q问:  
1 E1 t- V7 A$ V" j3 A0 ^4 N# z为什么Runtime.exec("ls")没有任何输出?  ) {3 ~' t0 I, ~
; Q8 G# K- t' t. c* R: s4 b
答:  
$ n, f3 P7 V8 x" [3 Z" H9 t3 W调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息. 由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向 子进程输入数据或获取子进程的输出. 所以正确执行Runtime.exec("ls")的例程如下:  
! M$ b8 e6 y( A, m9 x6 A: M! S; L, M( R, ~$ D

- l  P/ ~$ o+ b$ O2 ~2 H3 ptry  
% \: k8 W, w* E+ Y/ |: z2 K! R8 e
{  ! R. O  \' p9 j5 Y  D2 P/ I
; u+ F# _& p! m( A7 k  C
process = Runtime.getRuntime().exec (command);  8 ]" w5 c' _  p; I/ G% X1 x

  b+ u" Y* i0 P3 e2 nInputStreamReader ir=newInputStreamReader(process.getInputStream());  1 u  }& D5 `2 `- _/ V

1 ^8 L8 O2 |; ZLineNumberReader input = new LineNumberReader (ir);  
2 R7 S+ c) p* ~6 S
. B. e4 V/ ~; @: VString line;  ; ^3 Q. Q9 _) f' o) V
8 `6 c) d$ z6 K1 Q5 o+ F1 ?
while ((line = input.readLine ()) != null)  3 S" E: G' T& r. \
( i% \' k" \7 p9 r
System.out.println(line);  
, [9 i: L! r" p  d% S: q! \
' n- J  I0 v; [  h2 T0 l}  
2 Q6 J) |/ S% H( p5 Q
" N" ]% K% E2 Mcatch (java.io.IOException e){  
6 K/ i% o# @1 A  \8 M% W8 `% X) |" A
System.err.println ("IOException " + e.getMessage());  
! r- C, A5 |8 K3 {: y! U+ p3 |3 j# p- P% J
}  4 L4 C' f( i$ r, O$ u+ B+ B7 A

' S  w$ l5 o5 ?7 j( K7 c
; h0 R8 }8 J6 u1 {( C问:  
, y8 F6 X8 h/ P# U7 [5 ?如何产生签名applet,以使applet能够访问本地资源?  
& {  N+ U4 d. p0 G9 X+ D
7 A6 l/ }2 i2 ]; S答:  2 P& e4 ]! ^- T9 D( t; _2 E
在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料 请参考: http://java.sun.com/security/usingJavakey.html而java 2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java 2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:  ' h, F8 u6 y$ j( o6 d: l1 A

7 N" q2 v1 |& m, _
4 N3 y) |, N1 X* L+ R7 a: [6 T//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中  
1 r* T% ^' v0 H: X
9 p2 J- ]# l& M% P, N% f/ }# N  Dkeytool -genkey -alias joe -keypass sign12 -keystore joestore  
( F# }5 F4 J% u. C4 |
1 o) `4 a1 L- a5 @# P% |6 R, p//将SignedApplet.class及相关文件打包成jar文件  
0 t5 {) Z, s$ j! l9 X
* x9 a5 g9 a% w* o! r7 Bjar cvf SignedAppletDemo.jar  
8 r# D' m( z  T* G) ?% |, `5 S( O6 f3 ?+ z# y  Z, A
//利用keytool生成的自签名的证书产生签名applet(jar文件)  3 K& r2 T! T$ ~! a% B

2 C6 q1 z7 `5 ~, {7 ejarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe  
4 i6 b& P$ `- O" P/ {
/ T' k  U" P1 z3 u7 U//将自签名证书从keystore中输出到文件  3 g. m* l0 t# _% V. B- R3 E
/ Z( Z# U- l1 t9 r
keytool -export -keystore joestore -alias joe -file joe.cer    G" M  e& T& k( `9 n

- i4 A' B7 Q' q& Q8 L; A$ i0 o$ y: z$ m) Z

/ r2 Y' G- k7 ~4 g/ d2 n+ E而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行  
8 u2 q% P. ?  h) V5 y" W& l3 ]) L& z
2 D% T& {, I: kJoe编写的签名applet:  
$ G4 _: \1 h; |; y1 M( W) q' Y
5 @2 F* l, k, x/ d//得到Joe的证书并将之读入到密钥库中susanstore中  3 L, b2 K' c) @! w0 n2 \
: E, R, R# C$ l/ a$ W) O
keytool -import -alias joe -file joe.cer -keystore susanstore  6 \1 n, W$ M1 s- }
9 _( l- }4 G8 S/ Y, J
//运行policytool产生满足Susan要求的policy文件  4 S  T% c1 q/ T" z; Y- Y" o
8 `  a0 v, g7 x; m0 w4 C( @
policytool  
' ?; D( I: ~3 Q+ Y; p1 F! Q" P9 h  G
//用appletviewer运行之,或在浏览器中安装java plugin来运行之.  ' I+ P; f6 O" @# t
( @' j, P# [4 D: E  |
9 c' p, f/ S6 i" F. j% o, A

* `, I) i) a; Y  A; N, D关于签名applet在Java Plugin中的部署请参考以下网页:  
( @! @7 o7 w1 C* F- g5 q5 P- `5 P1 V& z# a$ E! e) O
http://java.sun.com/security/signExample12/  . p  s7 D" @( P1 M& `$ h  V; C7 a8 A
! Y$ w3 T5 n& }

; t9 P$ S! I5 C3 I$ s& A. h' M7 M2 b( u8 B6 O9 L5 n! L" [3 y. t2 T
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以  6 O, M: `7 I* `# o2 o! b

6 e. e( v3 `! @. d2 R! [* c7 s使用keytool -certreq向商业CA中心申请电子证书.  
) Y$ M$ e" X- s
+ {& E. J  y. I& v" X9 b
+ \3 r$ K" l5 M! g" B; I: T. i
* W% k: ~$ o: w, n5 v9 ~
6 E" x  E' N3 N( t问:  8 W5 B- c9 |8 O5 M5 E" N
若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?  
; O* K3 u( _+ [; Q$ D
# o0 ^# K8 u+ L) V答:  
$ P$ O( j! I* o* f# s使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.  1 q, `9 v1 t9 a
7 N& x) w. b) k# h2 _$ M1 K8 k3 q
问:  
" y* E* S( X  n. K9 _6 ~' k+ M. F对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?  
* R9 l* q7 I8 o0 T$ |4 Z( r; y+ J7 t) w* b7 h, k
答:  0 F  D! p7 X2 X: r  `& x# W: Q
目前,没有直接的方法可以将对象写入到随机存取文件中.  
* ]- ~- C, W( F- @" W6 I但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误. 例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.  0 G7 T+ j4 D( K
9 n1 H: r' B; \6 h) i; c
问:  - z0 ^( {# w" D1 ?" M
运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?  # h6 O9 b* G& z- y' q, U

% {2 M/ l# O# {, U$ s& J, E答:  # [4 }5 B& {1 J4 ?0 T
可以. java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(int port)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于获取名字服务.  
# Y2 T1 t. b/ U8 h7 X4 X* @1 O- O$ C; s% e' B' j2 F8 u' _
问:  4 k# D- O4 Y& a5 T5 o1 v7 I
使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?  
( q! O+ c. l# f# }' p# T
3 g) L; y( R9 P$ S) y9 ~4 L. o答:  
) O7 I' i, u8 }使用如下方法可以获得PrintJob的实例用于控制打印操作:  
% ]% ~% D; }% Z) U
8 U7 m5 P6 a% V' j$ }
' d3 V& q% y1 I0 P6 n2 g3 [# QToolkit.getPrintJob(Frame f, String jobtitle, Properties prop)  9 e3 Q) k6 X# Q' q, U
8 ^0 Y& D3 K& O' j
那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:  
+ E" m: j2 k2 B' k
# Z# X1 z+ E0 Pawt.print.destination: 可以是"printer"或"file"  
7 ?8 c: o+ ^( W2 ]3 {+ e; q" [" t" ?* r- s* Q+ V
awt.print.printer: 打印机名  
: r# o% B% A+ i8 F) E$ ]  ]# z  G) @6 F$ W* _
awt.print.fileName: 打印文件名  " `+ _% Y1 @, }" Z( h. Y% S" h

6 r: D% M3 x5 {: l! @awt.print.numCopies: 打印份数  
: a8 D7 @) u( n
3 A; N. W% M% ^awt.print.options: 打印命令的打印选项  
1 v; T2 [; l# }0 L" ]3 O' t9 u; z  q' J
awt.print.orientation: 打印方向,可以是"portrait"或"landscape"  ; u  X8 J) c8 i7 `0 D  K

6 j5 z4 U! x, Wawt.print.paperSize: 纸张大小,可以是"letter","legal","executive"或"a4"  2 w- f8 I7 i* b# \7 x# ?
, n$ e, e3 Y% `9 d# e2 o

5 W/ B8 ]1 h) x% e2 V' N7 ?
% L: c- M+ W0 ^* K& N* ?6 r' D
* B: G* [7 Q$ D; W* {1 S$ N
* L' n; y, K! K9 X( P
7 F" z: y$ n' A, o问:  * I$ u5 h3 f' T
在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?  " _; _' n6 D) D2 F; O6 s( c; G" P$ |7 L
* O7 @  A$ k& y$ [
答:  
8 w' p% a! f* u9 v9 k, mThread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.  
; S5 b6 G7 Z' g( C5 ]- `5 W4 D' x1 y
因此,在Java 2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.  & u- s. n2 R9 g5 `

+ A( Y, N- x9 G/ ]+ w, Y问:  
; l) ^& o$ {( v/ w使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?  
( I3 x  d/ b. T: h: d
! b: y/ B, a  H0 a- R答:  ) P2 H8 U6 Y0 h8 o
在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java 2中,ResultSet类增加了如下方法支持数据指针的移动,包括:  & H9 l: d& W! W% ?, h2 j; L6 q/ b
0 i, A$ S' _% x0 p, p0 {( b

" ^3 a& Y/ C( X( V  DResultSet.first():将数据指针移到结果集的第一行  
$ G$ q) h. k* B
; l* ?  h; i0 S9 K. y# ]+ J  P3 {ResultSet.last(): 将数据指针移到结果集的最后一行  
9 T1 Z! c' e+ |7 b
; S" K" R! v4 M5 {" n! [ResultSet.previous(): 将数据指针上移一行    l) l  i3 T4 b+ [
, ?" X1 p% ?- }$ i5 P# J1 g& a  `
3 X. }' ?4 s. q6 G2 ?* I
以上的方法定义在JDBC2.0的规范中,所有支持JDBC 2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC 2.0 .  
0 d: L" w! p; j
* u, o; R; H1 M! |$ Z8 J! B- V
问:  
7 A/ z& u8 Q( p* ^, z) L哪几种Web Server支持Servlet?如何使IIS支持Servlet?  
, e: a  b. o, D& g7 B3 i
" A: J! }& h/ S" |答:  
- Z9 `( [8 `% A8 B; ~" k目前,支持Servlet的服务器端产品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.  1 a. [2 q: T$ ?
) z. F6 F7 D, U) [
此外,一些第三方厂商也开发了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能够运行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.  ( I, |& a0 I. u6 I+ }

; {" k# W* k1 x+ A( C问:  ' h) h4 d( z0 S1 w' c
如何在Java应用中将图像存储到图像文件中?  
: c1 T* m  c4 f( q/ q# D
' p0 f. ~3 {7 u# H$ \1 g答:  , H) B, z' f2 f+ I$ q/ k
Java Advanced Imaging API(包含在Java Media API中)允许在Java应用中执行复杂的,高性能的图像处理.JAI API提供了存储图像的能力.目前,JAI API支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:  
( D. t4 _# T1 l( }" r4 ^
( [" \# j: c& G, ^0 k
3 E" y) }5 c- o; lOutputStream os = new FileOutputStream(fileToWriteTo);  ! F0 E; f, `+ T
+ |/ B& w1 O9 V
BMPEncodeParam param = new BMPEncodeParam();  0 m) d4 K. I' H* {/ j- Y
1 P% Q6 ~  w' @& C7 K
ImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);  8 v5 p6 l5 T- b# M* z5 q! o

/ o8 ~  ~! v7 }& L8 Aenc.encode(img);  
3 |3 q) ?# c+ {- G8 g1 W; L' C1 f! i6 W0 e
os.close();  * D9 H- O3 ^7 [- j0 m
7 g: C0 R- F, `
有关存储图像文件的编程指南请参考以下网页:  9 L: k% k, a. J- x

  b. N) g& y& j/ J. Dhttp://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/  
4 X% Z/ q4 J4 ]" Q% e* t2 f1 Q* H) V/ h+ @& r& p+ d6 M
/ R' g  J6 i/ F! `3 F7 U' f

# J( z% y5 X3 g5 i; E0 {3 S0 [/ N$ ?! y2 w" @  b- Y: N2 |/ w
问:  
2 B) E# ]6 u' n3 R* z* y如何用Java语言向串口读写数据? font>  & V: x/ L6 \! L+ [
6 l; k# S$ t9 J7 Y4 f: a$ G
答:  
7 g+ L! I5 c3 `6 x! BSun公司的Java Communication API2.0可用于读写串口,它支持RS232串口和IEEE 1284 并口,提供了一种与平台无关的串/并口通信机制.    \' H1 k9 x5 Y" R; v6 `- y/ T: i* j
1 Y+ a+ L7 Q6 E" e$ E; l# x- f' j
详细文档,请访问:<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-6-11 00:24 , Processed in 0.802368 second(s), 69 queries .

    回顶部