QQ登录

只需要一步,快速开始

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

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

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

206

主题

2

听众

882

积分

升级  70.5%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-3-31 01:31 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
问: 如何设置Java 2(JDK1.2)的环境变量?  
6 L" {, E0 [0 z: F5 V% \' p  y* ~2 W  B3 t  [
答: Java 2安装后,需要设置PATH和JAVA_HOME环境变量.与JDK1.1不同的是:设置好JAVA_HOME环境变量后,JVM将自动搜索系统类库以及用户的当前路径.  
/ g6 N3 r. i' V1 ]' NJava 2环境变量的设置如下例所示:  7 K% r6 K" C4 I% J, u0 r. N& l9 @
Solaris平台: setenv JAVA_HOME Java2的安装路径  ; X4 Y& V& v+ M
setenv PATH $JAVA_HOME/bin{PATH}  . j0 }8 {6 d; k/ i3 a* d
Windows平台: set JAVA_HOME=Java2的安装路径  
, N4 D) @( g2 ^4 [set PATH=$JAVA_HOMEbin;%PATH%  , ^$ s, {. h+ h

* l) _( y7 A. u6 ?( W  k问: 哪些Java集成开发工具支持Java 2?  
0 G: h% A) E8 \6 `7 ?" p3 B+ W" d; H, g  t( M. M# A( {) F2 R
答: 目前流行的Java集成开发环境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.  
8 s7 Q, n, z0 E% [2 f
1 S! h! u( H  K4 R) a8 M/ L. M问: 如果在Netscape或IE浏览器中运行Java applet时出现了错误,如何确定错误范围?  
2 U/ v' z+ y2 M$ _! P, c
9 s& M- `& n! E& i4 A5 [- l, N答: 当java applet在浏览器中运行时,使用的是浏览器本身的缺省JVM.而不同浏览器对JDK的支持程度也不尽相同. 因此,在Netscape或IE浏览器中运行Java applet出现了错误,建议使用JDK提供的工具appletviewer或Sun公司的Hotjava浏览器来测试该applet,以确定错误的产生是与浏览器相关.  ) k! Y  Y) F5 }
    如果applet在appletviewer或Hotjava中运行一切正常,则错误的产生是由于浏览 器不完全兼容JDK而引起的. 此时,解决方法可以是使用Hotjava浏览器或者安装 Sun公司的Java Plugin.  
- p  y, w$ Q0 I( w, F, `( b. W    如果applet在Hotjava浏览器或appletviewer中运行即发生错误,则应当根据错误 提示检查applet程序.  
/ }. l9 ^: m; {9 J, @6 O! H5 A6 ~: x/ w8 v2 m: I: X
问: 当用JDBC向数据库中插入数据或从数据库中提取数据时,为何有时中文字符会显示为乱码?  
7 Q6 ^7 }8 m: F; L' I; Y& y/ C$ K9 v9 U, c
答: 这个问题的实现通常与各个JDBC driver的实现有关. 目前大多数JDBC driver采用本地编码格式来传输中文字符,例如中文字符"0x4175"会被转成"0x41"和"0x75"进行传输. 因此我们需要对JDBC driver返回的字符以及要发给JDBC driver的字符进行转换.  
! J7 \( @' ~3 v6 }. d2 G
7 K2 f* [# D5 w1 R0 T  ?* E4 _( j; x当用JDBC driver向数据库中插入数据时,需要先将Unicode转成native code; 当 JDBC driver从数据库中查询数据时,则需要将native code转换成Unicode. 下面给出了这两种转换的实现:  
" d9 O5 @9 m' ~& m. v+ o3 m# `0 I9 f( u" u+ M& M5 I/ }
9 R- `3 m5 I9 ?8 R- R
String native2Unicode(String s) {  + V; x( [  _8 C* @& y! J1 b
' j+ I5 o1 c* ~3 N, r
if (s == null || s.length() == 0) {  
. y" b2 O" a+ R" K/ D. A2 K; [* q0 {6 v# l2 U& L
return null;  % ?$ u' a, J( j. L1 l6 }, Q- u0 R
" V" \% B8 Y2 O9 M" ]6 R
}  0 Z4 K( M0 @( s" b4 m% y; v* m5 i

7 k9 E2 B7 H6 Lbyte[] buffer = new byte[s.length()];  2 n: z5 \! s/ B2 y# x$ g
7 w2 `* p* D9 @# a2 o2 }/ V3 j
for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {  
8 @/ S. ^; J4 m  m* S6 l/ k& _8 T8 ~$ T8 M
c = s.charAt(i);  
/ R$ |( b/ S" p' L
  }; t# [+ i0 ^/ Y! k& q; I& V# Gbyte []buf = (""+c).getBytes();  - H$ [4 I. [! F7 M& ~# ~

5 V$ c9 L# r& [2 ubuffer[j++] = (char)buf[0];  
; t- U: \5 s! M! ^  {; W. y# S; Q6 c$ g( _6 i% n6 `
buffer[j++] = (char)buf[1];  
4 Z8 r7 o8 `2 r2 Q1 y) z9 u, `7 [+ c$ s' r
}  ) S! b; C/ u  D  q

  }' Z7 r+ B8 ^7 i# k0 {else {  ; J% a$ Y9 B' Q, J' `1 T. V
5 H8 O0 a/ e. P# b
buffer[j++] = s.charAt(i);  
( Z+ D1 m; e1 l- }9 ?& z( Q3 }
* m5 c; L# Y1 O( F) o/ ~}  6 K, @0 b3 V' G& l6 C& F9 h

7 X! `; y; }) p  i9 k}  
8 b2 E6 b) ~2 F. T& x+ ~( h( \. E7 ~4 B
; K( h2 H6 e+ T: `$ e: Hreturn new String(buffer, 0, j);  # b6 ^1 v/ n2 a' d' E
, O5 M) w1 t, _
}  
8 `: K, r! u) f' [+ j/ ?) x4 P1 W1 I" J! K& Y( y. K5 Q
除使用以上两个方法之外,有些JDBC driver如果对jdbc driver Manager设置了正确 的字符集属性,以上2个方法就不需要了.  
2 I4 C! {, v8 \' c4 z0 v7 v) X/ l# ^6 X2 r: R0 O5 L5 F
0 o' c4 U" G0 O2 o1 O, p1 y: o
问:  , p# e2 J: h9 ~' x8 K: M+ L
当用Servlet来处理http请求并产生返回的HTML页面时,如何使HTML页面中的中文字符能够正常显示?  1 }3 O8 S; d; T1 G8 o. W

3 d( i1 P8 O2 T0 p5 {% a答:  ) M2 L& Y  y( h: V9 B' ]
javax.servlet.http.HttpResponse类用于产生返回页面.通过HttpResponse定义的方法getOutputStream()可以获得ServletOutputStream的实例,这样用户就可以利用ServletOutputStream.write方法向输出流中写入返回页面的内容. 但是ServletOutputStream使用的是缺省的编码方式,如果要使返回页面中的中文字 符能够正常显示,最好显示地指定所用的字符编码方式. 通常需要构造一个 OutputStreamWriter , 例程如下:  6 }7 c2 T$ P8 A

% T6 w$ e3 s: I  c3 s( h# b
- d5 V; j7 ]( Y% B: D6 w0 h; Epublic void doGet (HttpServletRequest req, HttpServletResponse res)  " q" j# H2 T+ g7 k
% l4 a4 F/ i# `& S8 E
throws ServletException, IOException  1 E5 j2 o5 s/ ?& d4 X$ {' X: R6 u; p
9 B- u! S9 c) U
{  . K6 t- a; x  {$ G

$ X% A' ^9 D) P* }% nres.setContentType("text/html");  
% X6 h9 l; s- N' t! z" E9 i
% V! v, ~, {) S/ CServletOutputStream out = res.getOutputStream();  
7 d4 }+ T* ~7 c9 o
# K% P: D; o; S: F& oOutputStreamWriter ow = new OutputStreamWriter(out,"GB2312");  $ {$ e) F/ d- \; Q- M& `* D

% Y  M! d* q7 z0 kow.write("这是测试");  8 B# E4 |, w" `/ ?! C' I

4 C/ t1 S4 t+ E/ E1 i) B! v6 [/ iow.flush();  
, ]/ X" c* t3 R
8 u' N% Q. A, b8 n4 C- F* y; }ow.close();  4 i8 f) b: R1 |- e9 h! c8 A
- I; Q9 O5 B8 I1 l% ?4 @" j3 A
}  1 ?1 M2 i" D4 \9 m+ G

* |5 d, a! Q) H3 t
8 y  |2 j5 \0 F" U+ B: w# @问:  
" R6 Y/ Z8 {- V( @  v- g* ?如何设置Java WebServer的CLASSPATH,以包含用户的class文件?  
% V& `( x( p9 J. j7 N; p
+ ^' D# a: U" f/ D答:  
4 `, x4 ?/ n6 D0 q" m: q有两种方法可以设置Java WebServer的CLASSPATH环境变量,以使用户编写的Servlet能够调用用户的class文件.  
" A2 B+ _4 Y7 e将用户的class文件放到 JavaWebServer_Dir/classes目录下,在Java WebServer 启动时,classes目录被自动加入到CLASSPATH环境变量中了.  7 V! J, Y3 M3 g1 ~2 L
修改httpd.nojre文件,将用户class文件所在的路径名加到CLASSPATH环境变量中.  
( W. v& _( Y- x% {7 {% J" e; i* ^7 g; ^1 g
* V) g, \* j% C  f* R7 j
问:    P( S6 L6 N: w1 G
为什么在Windows平台上用Naming.lookup来获取远程RMI对象时会很慢?  
; C8 x" \! F+ W
+ k, j' O2 H- C+ p: n- c答:  
' ?( X/ l% q' D9 I4 `5 B& N( C0 P! ?- E机器的网络设置不正确很可能会引起该问题的发生.  & P$ p- x" j4 ?# [
RMI使用了Java网络类,特别是java.net.InetAddress类,它将查询TCP/IP的主机名, 包括IP地址到主机名的映射和主机名到IP地址的映射.在Windows平台,这种查询功能 是由本地的Windows Socket库来实现的. 因此延时是发生在Windows库中,而非RMI中.  
! O9 A7 L4 C, f- |7 D. C# T! w1 Y+ b1 W8 d, s
如果你的机器设置成使用DNS,问题通常是DNS服务器查不到主机名,你所发现的延时 是DNS查询的延时. 请尝试将RMI通信中涉及到的所有主机名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:  
" E* i8 x; w8 W: K1 E* l1 c" v- e3 p0 f
IP地址 主机名  
+ L% Z  B" S. A: V; O8 Q! }% o' V  n$ |* ^' D2 H
如此设置应当可以明显地减少查询所花的时间.  
0 _- Y  Y0 [& _& e% ?* ^
9 [( c! {* Y+ a6 [问: 编写Java application时,如何设置proxy的信息,以便访问外部网站?  
4 D  Q4 Y- e" D$ @$ i( ~
, g  Y0 s/ i- @+ d( |0 C' Y* m答:  ( q' {0 q; C$ Z0 Z
若在java application中访问外部网站,首先应设置proxy信息,样例代码如下:  
/ M. c) I- Z8 `. S7 C* Y0 m' _) Z" P" |( N( e6 n
7 z8 Q4 S7 Z( Z, z# ^9 |
import java.util.properties;  
, n2 u6 v% f& u: }. ?$ L* I/ L/ G5 J# K' Q
.....  $ e4 k! n5 I( `' z8 i
* I( k2 G3 ?8 E1 I6 U: f
Properties sys = System.getProperties();  
* \% \$ g, I5 f' T
: m6 X: H7 N6 ssys.put("proxySet","true");  
" j* c' {+ Q1 L5 y# s1 p* h# ~. g0 k' N. T' I+ Y+ M) e4 p; t
sys.put("proxyHost","myHTTP.proxyserver.com");  3 X+ R' i8 N% G9 }. \8 k' X

: H/ h  y8 p4 U% ~% i  Q6 y# asys.put("proxyPort","80");  
' N, x" Q' w" s. J( U( n; i3 m6 R) T9 Y0 N4 K. K1 N
System.setProperties(sys);  
% a* F8 H# n3 H) T) J% `6 `. C7 E. B! f: }3 J
: n4 H5 W) v% C% |7 c% H8 M
# V: [# M1 e' B7 q5 J! _: H4 j6 J
u = new URL(website);  
. [+ }. K4 c; b2 W: r! m: W; Z5 [. ?( _2 G
connect = (HttpURLConnection)u.openConnection();  " W2 J- Q& s! h5 I

9 E# J9 Z) n6 {0 T# g1 D3 G. D( H.....  % J; V* h+ A' S( [# T3 Z- \

. t. b  A; ~- X0 Q问: Swing组件JList的列表数据修改了,如何通知JList改变显示?  * L0 Z9 W) X" I) S) q& N. O

/ O3 x1 q) K) [: J& J' q; |5 Z& j$ [答:  2 b. T9 R$ j8 D/ p) Y( W9 l( \  i
JList组件有一个单独的显示模式ListModel来表示JList的显示数据.  
; x& e- b7 i: Z' ]0 KJList创建以后,JList数据元素的值及数据元素的数量可以动态地改变.  
) p# N6 Y  c  R+ g; ~# l! `JList在它的数据模式ListModel中观察数据的改变.因此,一个ListModel 的正确实现应当在每次数据发生改变时,通知事件的监听者.  ; |3 |' `. `/ Z0 _
当使用构造函数JList(Object[])创建一个JList的实例时,系统将自动 创建一个DefaultListModel的实例来存储JList的显示数据, 可以调用 DefaultListModel中定义的简便方法来动态地修改JList的数据,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改数据的同时,将通知JList关于数据的改变.  7 A7 R! T6 x) m( z) g1 ~
5 {: p) @: n/ q: @! ~5 v
问:  
3 c6 B1 _5 A: m1 z: g: i* M在Java applet中如何实现一个模式对话框?  
2 t( @0 e$ @" u7 i! p* @; @+ V& v, a( G
答:  - Z+ ^: h* `! b
在Java applet中实现模式对话框的关键就是在创建一个对话框的时候 要为该对话框指定一个正确的父窗口.因为Applet是Panel类的子类,不 可以作为对话框的父窗口,所以首先要获得applet所在的窗口,作为模式 对话框的父窗口. 样例代码如下:  ' ?8 o% {6 O$ ~4 Z  Y

; U, T1 b# `1 R" |' e# L/ |* A3 }" l9 z
.....  
, p; B4 g4 x# N( Q  f! K
7 n7 g1 b8 n$ BDialog d = new Dialog( getParentWindow(comp),title);  8 J$ c" b7 J+ K. L& z

, o0 ?8 ]+ l& T# P// comp为applet上的任意一个组件  
, s4 J; G$ ?) M7 ]! b# F) T. P- p! N* U/ c3 n& d, B$ m, ?7 e
....  
' u# Q* d; [6 d$ j: X+ D- M; G2 e$ g" V
2 w/ T  Z) N  L9 n7 u
0 T8 z- R* G( B0 Q4 C3 A( n
public void getParentWindow(Component compOnApplet,String title){  
) J) W6 D% z0 s' U
) V0 d, y. F/ a5 R- j+ KContainer c = compOnApplet.getParent();  
+ |7 ^2 q8 f& _5 q4 o0 Z  d; F' q' ^9 y. |$ z2 Z% k
while (c != null) {  4 }$ A' a$ }' e( N  W2 n. q* b
$ L: q1 Q% `* X8 i
if (c instanceof Frame)  6 S/ }8 M+ N# j$ v3 W
" O' I4 h6 _" }1 x) ^5 t0 D$ ~6 r
return (Frame) c;  
6 H4 p0 [  R% |: j- R$ a8 d* V6 G0 }. P( ^' e  C& h
c = c.getParent();  ' C, g! g/ Q4 @# B5 z

. ^- `5 J  }8 T0 Q  `" n; h# L9 K}  
* r% M0 o9 \. }9 b9 S$ t5 Q5 G5 h5 @& i
return null;  
- x* b' e1 E' Y3 T4 F8 n+ A1 H6 t2 K; m& P
}  
' x- H) T; B; V
0 \+ Y; n, `* s问: 在Java applet中如何显示另外一个HTML页面?  & a$ n; B  Y3 w; N
" y/ b. C  B/ |2 Z
答:  
; n* b9 Z! G' v8 ^通过java.applet.Applet.getAppletContext()方法可以获得与该applet相关的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的浏览器显示另外一个网页.  " U+ r  R- S* H
0 |3 K% B" g6 k1 A3 p7 @3 k- M
问:  
. L1 |+ @" s: S8 W! J2 b用JDK实现的签名applet,可否在Netscape或IE中运行?  
4 F1 n8 E) Q* L) r3 U) s2 A; B; ]% \+ D
答:  8 y* J# A* ]# ~3 o$ v" |
用JDK实现的签名applet,不可以在Netscape或IE中运行,但是可以在Hotjava浏览器中运行.  
( w' v! u  Z) [- X( [# h  ^" j5 D& z1 h9 {  K& B/ U0 M
不同的浏览器提供了不同的签名applet机制,如Netscape提供了zigbert工具和 Capability API, 而IE则需要使用CAB文件. 但是,无论是Netscape工具产生的 签名applet,还是用IE产生的签名applet,都不可以在其它的浏览器中运行.  
; k; ^/ a: ]3 ^9 t' I+ [* L; r5 u# l5 E5 {5 d! [$ ~, u
如果要使JDK产生的签名applet能够在Netscape或IE中运行,解决方法是在 Netscape或IE中安装Java Plugin,则用JDK实现的签名applet就可以在这两种 浏览器中运行.  
4 I4 y' z- N/ r% a2 l+ j' S) ^( }! _! a7 N1 \
问:  
- L8 z7 I" r$ W" L$ p6 J! z4 i用JNI技术可以从Java应用中调用C程序库,但是如何使该C程序库可以调用另外的C程序库?  7 M& O* g- d. n$ w' y
2 ?  A4 ]0 `" Q( `* B. @
答:  
0 E) F1 v" O7 |  ^如果一个被Java调用的C程序库C1仍需要调用另外一个C程序库C2,那么在编译C1的时候应当联接程序库C2,步骤如下(Solaris平台):  
- l' e0 M% ^# D9 L编写调用C库的Java文件,并编译.  
' g7 E  V5 T% j+ gjavac java文件名  , q* S# s# @$ C
2 I3 L% V; D0 {* G

- _5 g; h& v( B9 ]+ e1 V* ~( h产生C程序头文件  
* C3 q7 c  E7 @4 N* ~0 L1 `1 G6 Ojavah -jni java文件名(不带后缀.java)  ( C1 C9 ]% D$ I! ?1 G2 G
- Q; ?3 ]" s7 z2 z( U  O# h6 m
4 k$ b; K/ p+ t, m# C3 J
编写被Java调用的C程序C1.c,以及被C1调用的C2.c,并编译.  - Q6 c  y* H1 Z* d4 f/ |9 E
cc -G -Iinclude路径名 C2.c -o libC2.so  ; U; u$ d+ n6 w7 V' h/ o3 h
cc -G -Iinclude路径名 -lC2 C1.c -o libC1.so  
3 t8 e8 _8 D, `( Y# P& o
5 R5 j9 n9 u* @( H9 z+ U2 Q) `' V
' ^2 F6 c' \$ X" Q, i# H设置环境变量  
7 N1 b! ?2 _0 V% {6 s& h8 dsetenv LD_LIBRARY_PATH libC1.so,libC2.so所在路径  
: D; H. n( y1 \0 |: W9 K{LD_LIBRARY_PATH}  
9 |6 H! [& ?- ]$ W
, D# |/ X, K! q& L  \
7 m" L; {. W$ Q& M0 V4 J运行java应用    I3 j2 [- j8 l

& s0 Q$ P& s8 B" r& q# z* U6 y( \; c8 ]. d
问:  9 \8 C3 V. V3 ?1 ~3 U$ C
在Java语言中,如何列出PC机文件系统中的所有驱动器名?  
4 w9 M1 ], v8 C- I7 {  s2 A4 i0 o, O- J/ O3 Y
答:  ) v; w( N( O# y6 c
在Java 2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.  
5 L) a/ B0 [1 U$ Z9 N$ W
: m) K5 P/ K6 K问:  
4 _7 f/ V+ D2 k为什么Runtime.exec("ls")没有任何输出?  
, ~: ]7 \* l# q! `
4 s1 q- o5 s$ u& }# L答:  
# c4 T3 k/ Q6 ^+ V3 c调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息. 由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向 子进程输入数据或获取子进程的输出. 所以正确执行Runtime.exec("ls")的例程如下:  4 v8 c$ S1 o# R" k( j3 w
% w: ?9 ~+ @/ O0 J/ C9 i! h) G+ i
# P. C$ r9 W0 p, z6 f
try  8 w, e9 v7 h8 b4 W2 |- v
" m& r9 a8 L' ~6 L6 q
{  % N; U0 n# U& _- c
( q7 b: L9 B2 I9 x2 R1 M8 m
process = Runtime.getRuntime().exec (command);  ' Q, m' l- n. \8 o  @' e* ~9 A
5 d9 L4 r* C+ Y% u) G
InputStreamReader ir=newInputStreamReader(process.getInputStream());  ; T* l+ J" |& N! Q0 t. u/ c8 W

: h% D! v" {8 A2 M$ v/ j% b; oLineNumberReader input = new LineNumberReader (ir);  ( E2 N! Q0 M9 l( R! O
! D3 D+ p0 \" w- n/ q
String line;  
9 d# V; R: h1 g2 C  s) a* f/ q  ^* y* O( |+ N# R4 l) I
while ((line = input.readLine ()) != null)  % h6 W7 T, Y6 ?9 b

' \& i1 D. }' l$ Z" |System.out.println(line);  
0 _  I5 i3 L0 B
& X9 o. \, L+ }% V5 K* f}  
8 i3 n/ l& ^& V9 @% F0 a
. w; k7 P% X' S9 d( A3 d( Fcatch (java.io.IOException e){  
& O0 {# c2 H& _+ _, o# [3 w" k4 B0 [- g3 D1 x8 M  W; I
System.err.println ("IOException " + e.getMessage());  ( T8 x! v( q0 @9 ]) c6 k5 d. U

4 E" ?* I! y  z0 d4 j+ s}  / D3 j' Z5 x3 \: {& ]
9 I! M1 \4 i5 ?9 h' ^1 w
0 ]) f3 ^  d9 q1 S
问:  
/ a7 p& Y# @) H5 ?+ O3 \如何产生签名applet,以使applet能够访问本地资源?  
8 r" G8 C# d1 h# ~: S! E2 ?8 Q# }9 f* P5 x2 Y$ N
答:  
( I. X4 @; z9 d& W$ I在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料 请参考: http://java.sun.com/security/usingJavakey.html而java 2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java 2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:  
, e: u* F6 ]+ ]# b. [$ A" r
8 X; ^$ B- k5 y  H5 {7 d
8 ~, S- b8 O$ I1 U/ W$ @# l$ {7 e; r' O//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中  
0 h; w( n' d/ O+ |6 `/ D6 d
' b; }% h) h9 _; `4 pkeytool -genkey -alias joe -keypass sign12 -keystore joestore  ( ]% y% _1 `: n( \6 Z3 Z9 f

1 \# I, i' ~5 V" y- d4 E: c5 h//将SignedApplet.class及相关文件打包成jar文件  
5 J! K2 B  _8 a9 M$ i! @; v! H+ E( @4 y8 `: O  t
jar cvf SignedAppletDemo.jar  ) [+ I/ q! z1 C2 y
& n& i$ \# {; `4 ~1 M
//利用keytool生成的自签名的证书产生签名applet(jar文件)  # N4 p/ {+ d1 q$ B- T2 K5 H) S

  |5 J2 R/ C5 A5 w. g3 o! g; F7 njarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe  
3 d, p( F1 A9 v; b) J3 E4 e/ P3 V. s; q0 e; ^- P/ }# ~
//将自签名证书从keystore中输出到文件  
" o3 u# r& i2 e+ [+ T4 J' W1 F" B% v5 n& y  i9 _0 U1 s+ n! I
keytool -export -keystore joestore -alias joe -file joe.cer  
, j3 O( g6 W9 ~4 X: B! Y
) C0 p7 R# o, A' U# e0 T, u9 U# w! V6 w

1 l1 Z- i0 i$ j! {/ c而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行  
! c6 W8 F# I) @- e7 T7 O: P4 V
$ ^' O( o% A6 U. f* TJoe编写的签名applet:  6 J1 }4 ?) s# M6 Y' L7 ^
2 n4 a% i% ^9 P8 f5 k
//得到Joe的证书并将之读入到密钥库中susanstore中  
! w  R7 c- i' u: w" w7 Z* u+ W. [0 x: i# E) e4 \
keytool -import -alias joe -file joe.cer -keystore susanstore  ! R  U, P! s+ @$ Y$ w2 o  k

  `, _! c9 S- X0 \+ B% y//运行policytool产生满足Susan要求的policy文件  
- h& h9 {; \9 F0 x
8 L" m; d. c$ k: V6 S9 g! P4 spolicytool  ( v* K% t* z$ ?

: A, L8 {7 s  ^& s8 W: j//用appletviewer运行之,或在浏览器中安装java plugin来运行之.  . ]$ q0 P7 H3 x* W9 s7 y
0 {+ u4 |  g' V
- \$ X' M  B' f: G' J8 E' H
1 R2 A: m5 B* b1 X! h$ e
关于签名applet在Java Plugin中的部署请参考以下网页:  " p( s5 u5 j. ]- ^. l- A
+ q" l" _& E' U* n
http://java.sun.com/security/signExample12/  
5 X8 D! X9 p6 Q& A9 q; G" n* T& T/ \' I* m: M! B  a
3 s" U) H7 n" W) n2 l( h
: c, P$ S6 o: a- x1 ~8 y" a# Z
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以  7 o0 A4 T& Q$ \! f( w7 D

# d9 u+ D, D: E4 i2 }. u9 w6 ]使用keytool -certreq向商业CA中心申请电子证书.  - B. j7 B2 ?& Q5 Z) [6 L0 L
8 K) M# W  W3 J2 B% i
  c% ~- u  C5 v0 F$ E% ?

2 I: _' @9 X1 m# F/ n% |6 N5 T+ K0 i4 q: f9 o9 }4 w
问:  
& U2 F1 D2 Q3 ~, m若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?  
! m+ W' x/ j9 D. K# r4 v: d( g! }8 m4 }! [. j9 o, D
答:  4 k1 x8 Z4 c7 z
使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.  
# P& P+ T0 q. d# [) a
  X3 [9 k/ \# ^% B* x8 X问:  * K5 s1 D' K. E. A
对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?    ?. q2 R; E& i% n

+ Y% B  x$ r, L& X; g+ _2 |答:  
5 v3 G4 P, @! J5 Y5 ^目前,没有直接的方法可以将对象写入到随机存取文件中.  
+ L: N7 v6 X$ |# T但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误. 例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.  1 C& t  \' S* }6 U  E: y  `( \6 d

) m+ V$ q; t2 u$ M问:  5 R- t! u( a- v
运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?  # h7 C8 O8 L5 W; a' ~% i9 F

5 p" s( ~3 J  Z7 l3 r9 a答:  
/ ~! \; I4 `, |6 S" g- w: a可以. java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(int port)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于获取名字服务.  ' q, M  P; J) x# b9 Y5 F$ D
( U2 D) q. Z) h5 a0 ]* M
问:  0 B) ~1 F& X  Q
使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?  * y3 Q* q5 a. R! }$ h' K
8 k$ {: Q+ ~5 H1 H# k* `0 w
答:  
/ c7 A2 ^0 c' ^/ V5 }; @) V# H& u使用如下方法可以获得PrintJob的实例用于控制打印操作:  
6 r, \: e1 o! O: |7 x9 c" O( t+ a" P- H9 E2 a$ G

! ]+ _; ]5 Q5 U- P2 aToolkit.getPrintJob(Frame f, String jobtitle, Properties prop)  
8 h2 |- A  g9 U$ ~. Y
. u+ E! p& ^! n" }& x0 a6 ^/ s那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:  
: H, y" @* v  S9 D+ r5 C. A" i6 v7 E0 m& K$ p
awt.print.destination: 可以是"printer"或"file"  5 B3 v. s. ?! w- q9 S0 H
( R- l8 g) ]4 c* W( ~! F" }
awt.print.printer: 打印机名  
. D! e6 y7 O7 k- S# f4 e- J$ F. X8 |4 W% A' o
awt.print.fileName: 打印文件名  
. C. {0 V, g5 ~- Z* k- b" T$ R9 T: X& q" B  x# p/ o
awt.print.numCopies: 打印份数  
9 I# |! K' ]6 p+ @: k* Z$ n4 F) a; @
) j2 u' `. }; Q$ N! _3 iawt.print.options: 打印命令的打印选项  - n7 K9 L, a# |6 W& x# |( d

& w) y3 I6 ~7 ?( L- pawt.print.orientation: 打印方向,可以是"portrait"或"landscape"  
' R" K% F0 `/ n( s( M1 ]
2 e2 ]2 _4 H# l4 W) ]  ]awt.print.paperSize: 纸张大小,可以是"letter","legal","executive"或"a4"  
  \' v( E( ]4 C; P# d! {$ |  ^/ h( A* V

0 u, \! \) K, }7 F" N! j2 O# w5 }" `
6 r- m7 U" z7 }8 h7 W- k0 }1 a

: t/ k% {! Z6 N0 [. s
8 y( V# l& o( D- q- e/ M* F问:  ( {. F3 S- w5 {" r8 O6 p2 d; H: N
在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?  & z* U  a& h5 m1 u

* F9 r, r. a+ K答:  , y2 P8 o/ y8 t5 s, f- W% x
Thread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.  
; m) O$ S* ?0 w' O
+ s$ A1 R5 I% C" W7 ^' E因此,在Java 2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.  
$ Q+ y) o: Q. n, Z3 W& e4 _+ c" R; {  a2 }5 @+ O
问:  
' s: g+ f' @/ y1 P( Q: V使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?  
" l  r  E" g+ a, W
. s/ n5 e/ Z4 [8 s! t( D3 k答:  
* D8 Y! {8 Y. z: A6 _% }1 R在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java 2中,ResultSet类增加了如下方法支持数据指针的移动,包括:  1 y. c# q6 v% M" N4 O" f
' L% B+ X  N( l# P' ]. E

8 C3 [5 C# x4 G5 o9 [ResultSet.first():将数据指针移到结果集的第一行  0 L' ~# I8 ~, _3 v

" m+ o1 i) i5 g: t/ A  J& CResultSet.last(): 将数据指针移到结果集的最后一行  ( Z2 k: S* P( \2 X/ w& M

( x- L/ l7 V3 Q! U$ Q/ j! @ResultSet.previous(): 将数据指针上移一行  6 E, v0 ?' P# X
4 W/ d. |- w1 m; _- N

+ Z$ a- J4 W4 _) F; B9 b以上的方法定义在JDBC2.0的规范中,所有支持JDBC 2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC 2.0 .  " `( ?. Z, i6 U5 ?, j

9 l! h5 }8 k  a/ x- q* L* g2 K3 p- r% r- I& t( X& P/ u
问:  " Q3 D7 o; Z2 R" S% S8 e  w: _
哪几种Web Server支持Servlet?如何使IIS支持Servlet?  . C' c+ A: I1 g& b
6 e" P9 {5 Z( A2 E- A
答:  
! f6 q, X, `/ E目前,支持Servlet的服务器端产品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.  ( L3 S: A+ ^- }5 j( q7 J+ t! t
0 A, k% k  v. r) V: I- b' h- o7 O
此外,一些第三方厂商也开发了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能够运行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.  
( f; P, ?+ ~; I1 A* f0 \; t, G/ T7 _) ~
问:  
$ ]+ T* `  M& c, P$ u如何在Java应用中将图像存储到图像文件中?  
1 n+ M+ A. I" a$ u% v7 ~
6 o% y: Z- m9 T: Q- q! y答:  ! B! y. e, H5 m* P( Z! a
Java Advanced Imaging API(包含在Java Media API中)允许在Java应用中执行复杂的,高性能的图像处理.JAI API提供了存储图像的能力.目前,JAI API支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:  . g+ U1 O9 h7 w" X- |) g
+ h/ A; W3 ?, z9 Z" E
  ^* a# ^/ Z$ w
OutputStream os = new FileOutputStream(fileToWriteTo);  
" i% W# w5 r# c$ e0 S
& C5 y$ t* k- d. \1 l$ cBMPEncodeParam param = new BMPEncodeParam();  
' R. g7 V3 ~  r+ q1 G8 ]6 n% }" O, |& V& Y8 r; i7 w0 m
ImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);  & w$ x% h% t! v, o% s9 f

7 c3 y, Z/ q- {enc.encode(img);  
) @8 B* N! Q* B8 p5 x6 z1 R# d) r, D+ R- B. _4 b: Q4 E) x
os.close();  . t# q0 i5 h' u5 w8 i1 A  Z
% R% G  u( B1 A# _/ E7 E
有关存储图像文件的编程指南请参考以下网页:  9 u' Z3 {' j+ L: t5 T

- y# h; V6 o* n: Jhttp://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/  
( R8 Z7 V" [( p; J2 ]3 V6 R
/ Z3 A" s" K5 w) }8 M: c" ^" z6 B! z7 b- w3 `

" T9 Y3 K  G; R- n; `, [
$ j* Z/ Y! T0 c4 W' W7 A; t7 w0 v  K问:  
% Q* o/ W. j: }如何用Java语言向串口读写数据? font>  ! F: H; v; g( b! d3 A
+ g( j% Z* `; z8 w0 W! Y$ r
答:  
, m5 @! P. f$ U9 F& JSun公司的Java Communication API2.0可用于读写串口,它支持RS232串口和IEEE 1284 并口,提供了一种与平台无关的串/并口通信机制.  7 }- v" j% y9 B- p0 o2 O, K
' D; F0 h4 w/ [* g! A+ R$ Y
详细文档,请访问:<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-12 08:23 , Processed in 0.472621 second(s), 69 queries .

    回顶部