Csdn-Blog <script language="javascript" src="http://www.023rcsc.com/count/count2.asp"></script>
cc-G-Iinclude路径名C2.c-olibC2.so
cc-G-Iinclude路径名-lC2C1.c-olibC1.so 设置环境变量
setenvLD_LIBRARY_PATHlibC1.so,libC2.so所在路径
{LD_LIBRARY_PATH}
运行java应用
问: 在Java语言中,如何列出PC机文件系统中的所有驱动器名?
答:在Java2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.
问:为什么Runtime.exec("ls"没有任何输出?
答:调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息.由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(),Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向子进程输入数据或获取子进程的输出.所以正确执行Runtime.exec("ls"的例程如下: try {
process=Runtime.getRuntime().exec(command);
InputStreamReaderir=newInputStreamReader(process.getInputStream());
LineNumberReaderinput=newLineNumberReader(ir);
Stringline;
while((line=input.readLine())!=null)
System.out.println(line); }
catch(java.io.IOExceptione){
System.err.println("IOException"+e.getMessage());
问:如何产生签名applet,以使applet能够访问本地资源?
答:在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料请参考:
http://java.sun.com/security/usingJavakey.html
而java2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:
//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中
keytool-genkey-aliasjoe-keypasssign12-keystorejoestore
//将SignedApplet.class及相关文件打包成jar文件
jarcvfSignedAppletDemo.jar
//利用keytool生成的自签名的证书产生签名applet(jar文件)
jarsigner-keystorejoestore-signedjarjoe.jarSignedAppletDemo.jarjoe
//将自签名证书从keystore中输出到文件
keytool-export-keystorejoestore-aliasjoe-filejoe.cer
而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行
Joe编写的签名applet:
//得到Joe的证书并将之读入到密钥库中susanstore中
keytool-import-aliasjoe-filejoe.cer-keystoresusanstore
//运行policytool产生满足Susan要求的policy文件
policytool
//用appletviewer运行之,或在浏览器中安装javaplugin来运行之.
关于签名applet在JavaPlugin中的部署请参考以下网页:
http://java.sun.com/security/signExample12/
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以
使用keytool-certreq向商业CA中心申请电子证书.
问:若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?
答:使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.
问:对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?
答:目前,没有直接的方法可以将对象写入到随机存取文件中.
但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误.例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.
问:运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?
答:可以.java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(intport)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(Stringhost,intport)方法可用于获取名字服务.
问:使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?
答:使用如下方法可以获得PrintJob的实例用于控制打印操作:
Toolkit.getPrintJob(Framef,Stringjobtitle,Propertiesprop)
那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:
awt.print.destination:可以是"printer"或"file"
awt.print.printer:打印机名
awt.print.fileName:打印文件名
awt.print.numCopies:打印份数
awt.print.options:打印命令的打印选项
awt.print.orientation:打印方向,可以是"portrait"或"landscape"
awt.print.paperSize:纸张大小,可以是"letter","legal","executive"或"a4"
问:在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?
答:Thread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.
因此,在Java2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.
问:使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?
答:在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java2中,ResultSet类增加了如下方法支持数据指针的移动,包括:
ResultSet.first():将数据指针移到结果集的第一行
ResultSet.last():将数据指针移到结果集的最后一行
ResultSet.previous():将数据指针上移一行
以上的方法定义在JDBC2.0的规范中,所有支持JDBC2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC2.0.
问:哪几种WebServer支持Servlet?如何使IIS支持Servlet?
答:目前,支持Servlet的服务器端产品主要有:Sun公司的JavaWebServer,LotusDominoGoWebServer,BEAweblogicTengahServer,Jigsaw,NetForge,AcmeServer和MotBaysJetty等.
此外,一些第三方厂商也开发了Servletengine,以使其它WebServer(如NetscapeWebServer,IIS等)能够运行Servlet,如LiveSoftware的Jrun(
http://www.livesoftware.com/
products/jrun/)等.
问:如何在Java应用中将图像存储到图像文件中?
答:JavaAdvancedImagingAPI(包含在JavaMediaAPI中)允许在Java应用中执行复杂的,高性能的图像处理.JAIAPI提供了存储图像的能力.目前,JAIAPI支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:
OutputStreamos=newFileOutputStream(fileToWriteTo);
BMPEncodeParamparam=newBMPEncodeParam();
ImageEncoderenc=ImageCodec.createImageEncoder("BMP",os,param);
enc.encode(img);
os.close();
有关存储图像文件的编程指南请参考以下网页:
http://java.sun.com/products/jav...velopers/jai-guide/ 问:
如何用Java语言向串口读写数据?font> 答:
Sun公司的JavaCommunicationAPI2.0可用于读写串口,它支持RS232串口和IEEE1284并口,提供了一种与平台无关的串/并口通信机制.
Java常见问题集锦(来自sun官方) (下) src="http://www.023rcsc.com/count/iframe2.asp" frameborder="0" width="650" scrolling="no" height="160">
Java常见问题集锦(来自sun官方) (下)
以及被C1调用的C2.c,并编译.cc-G-Iinclude路径名C2.c-olibC2.so
cc-G-Iinclude路径名-lC2C1.c-olibC1.so 设置环境变量
setenvLD_LIBRARY_PATHlibC1.so,libC2.so所在路径
{LD_LIBRARY_PATH}
运行java应用
问: 在Java语言中,如何列出PC机文件系统中的所有驱动器名?
答:在Java2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.
问:为什么Runtime.exec("ls"没有任何输出?
答:调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息.由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(),Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向子进程输入数据或获取子进程的输出.所以正确执行Runtime.exec("ls"的例程如下: try {
process=Runtime.getRuntime().exec(command);
InputStreamReaderir=newInputStreamReader(process.getInputStream());
LineNumberReaderinput=newLineNumberReader(ir);
Stringline;
while((line=input.readLine())!=null)
System.out.println(line); }
catch(java.io.IOExceptione){
System.err.println("IOException"+e.getMessage());
问:如何产生签名applet,以使applet能够访问本地资源?
答:在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料请参考:
http://java.sun.com/security/usingJavakey.html
而java2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:
//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中
keytool-genkey-aliasjoe-keypasssign12-keystorejoestore
//将SignedApplet.class及相关文件打包成jar文件
jarcvfSignedAppletDemo.jar
//利用keytool生成的自签名的证书产生签名applet(jar文件)
jarsigner-keystorejoestore-signedjarjoe.jarSignedAppletDemo.jarjoe
//将自签名证书从keystore中输出到文件
keytool-export-keystorejoestore-aliasjoe-filejoe.cer
而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行
Joe编写的签名applet:
//得到Joe的证书并将之读入到密钥库中susanstore中
keytool-import-aliasjoe-filejoe.cer-keystoresusanstore
//运行policytool产生满足Susan要求的policy文件
policytool
//用appletviewer运行之,或在浏览器中安装javaplugin来运行之.
关于签名applet在JavaPlugin中的部署请参考以下网页:
http://java.sun.com/security/signExample12/
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以
使用keytool-certreq向商业CA中心申请电子证书.
问:若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?
答:使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.
问:对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?
答:目前,没有直接的方法可以将对象写入到随机存取文件中.
但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误.例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.
问:运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?
答:可以.java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(intport)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(Stringhost,intport)方法可用于获取名字服务.
问:使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?
答:使用如下方法可以获得PrintJob的实例用于控制打印操作:
Toolkit.getPrintJob(Framef,Stringjobtitle,Propertiesprop)
那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:
awt.print.destination:可以是"printer"或"file"
awt.print.printer:打印机名
awt.print.fileName:打印文件名
awt.print.numCopies:打印份数
awt.print.options:打印命令的打印选项
awt.print.orientation:打印方向,可以是"portrait"或"landscape"
awt.print.paperSize:纸张大小,可以是"letter","legal","executive"或"a4"
问:在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?
答:Thread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.
因此,在Java2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.
问:使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?
答:在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java2中,ResultSet类增加了如下方法支持数据指针的移动,包括:
ResultSet.first():将数据指针移到结果集的第一行
ResultSet.last():将数据指针移到结果集的最后一行
ResultSet.previous():将数据指针上移一行
以上的方法定义在JDBC2.0的规范中,所有支持JDBC2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC2.0.
问:哪几种WebServer支持Servlet?如何使IIS支持Servlet?
答:目前,支持Servlet的服务器端产品主要有:Sun公司的JavaWebServer,LotusDominoGoWebServer,BEAweblogicTengahServer,Jigsaw,NetForge,AcmeServer和MotBaysJetty等.
此外,一些第三方厂商也开发了Servletengine,以使其它WebServer(如NetscapeWebServer,IIS等)能够运行Servlet,如LiveSoftware的Jrun(
http://www.livesoftware.com/
products/jrun/)等.
问:如何在Java应用中将图像存储到图像文件中?
答:JavaAdvancedImagingAPI(包含在JavaMediaAPI中)允许在Java应用中执行复杂的,高性能的图像处理.JAIAPI提供了存储图像的能力.目前,JAIAPI支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:
OutputStreamos=newFileOutputStream(fileToWriteTo);
BMPEncodeParamparam=newBMPEncodeParam();
ImageEncoderenc=ImageCodec.createImageEncoder("BMP",os,param);
enc.encode(img);
os.close();
有关存储图像文件的编程指南请参考以下网页:
http://java.sun.com/products/jav...velopers/jai-guide/ 问:
如何用Java语言向串口读写数据?font> 答:
Sun公司的JavaCommunicationAPI2.0可用于读写串口,它支持RS232串口和IEEE1284并口,提供了一种与平台无关的串/并口通信机制.
Java常见问题集锦(来自sun官方) (下) src="http://www.023rcsc.com/count/iframe2.asp" frameborder="0" width="650" scrolling="no" height="160">