Sung in Blog

                     一些技術文章 & 一些生活雜碎
          問:如何設置Java 2(JDK1.2)的環境變量?

          答: Java 2安裝后,需要設置PATH和JAVA_HOME環境變量.與JDK1.1不同的是:設置好JAVA_HOME環境變量后,JVM將自動搜索系統類庫以及用戶的當前路徑.
            Java 2環境變量的設置如下例所示:
            Solaris平臺: setenv JAVA_HOME Java2的安裝路徑
            setenv PATH $JAVA_HOME/bin:${PATH}
            Windows平臺: set JAVA_HOME=Java2的安裝路徑
            set PATH=$JAVA_HOMEbin;%PATH%

            問: 哪些Java集成開發工具支持Java 2?
            答: 目前流行的Java集成開發環境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.

            問: 如果在Netscape或IE瀏覽器中運行Java applet時出現了錯誤,如何確定錯誤范圍?
            答: 當java applet在瀏覽器中運行時,使用的是瀏覽器本身的缺省JVM.而不同瀏覽器對JDK的支持程度也不盡相同. 因此,在Netscape或IE瀏覽器中運行Java applet出現了錯誤,建議使用JDK提供的工具appletviewer或Sun公司的Hotjava瀏覽器來測試該applet,以確定錯誤的產生是與瀏覽器相關.
            如果applet在appletviewer或Hotjava中運行一切正常,則錯誤的產生是由于瀏覽 器不完全兼容JDK而引起的. 此時,解決方法可以是使用Hotjava瀏覽器或者安裝 Sun公司的Java Plugin.
            如果applet在Hotjava瀏覽器或appletviewer中運行即發生錯誤,則應當根據錯誤 提示檢查applet程序.

            問: 當用JDBC向數據庫中插入數據或從數據庫中提取數據時,為何有時中文字符會顯示為亂碼?
            答: 這個問題的實現通常與各個JDBC driver的實現有關. 目前大多數JDBC driver采用本地編碼格式來傳輸中文字符,例如中文字符"0x4175"會被轉成"0x41"和"0x75"進行傳輸. 因此我們需要對JDBC driver返回的字符以及要發給JDBC driver的字符進行轉換.
            當用JDBC driver向數據庫中插入數據時,需要先將Unicode轉成native code; 當 JDBC driver從數據庫中查詢數據時,則需要將native code轉換成Unicode. 下面給出了這兩種轉換的實現:
            String native2Unicode(String s) {
            if (s == null' 's.length() == 0) {
            return null;
            }
            byte[] buffer = new byte[s.length()];
            for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {
            c = s.charAt(i);
            byte []buf = (""+c).getBytes();
            buffer[j++] = (char)buf[0];
            buffer[j++] = (char)buf[1];
            }
            else {
            buffer[j++] = s.charAt(i);
            }
            }
            return new String(buffer, 0, j);
            }
            除使用以上兩個方法之外,有些JDBC driver如果對jdbc driver Manager設置了正確 的字符集屬性,以上2個方法就不需要了.

          問: 當用Servlet來處理http請求并產生返回的HTML頁面時,如何使HTML頁面中的中文字符能夠正常顯示?
            答: javax.servlet.http.HttpResponse類用于產生返回頁面.通過HttpResponse定義的方法getOutputStream()可以獲得ServletOutputStream的實例,這樣用戶就可以利用ServletOutputStream.write方法向輸出流中寫入返回頁面的內容. 但是ServletOutputStream使用的是缺省的編碼方式,如果要使返回頁面中的中文字 符能夠正常顯示,最好顯示地指定所用的字符編碼方式. 通常需要構造一個 OutputStreamWriter , 例程如下:
            public void doGet (HttpServletRequest req, HttpServletResponse res)
            throws ServletException, IOException
            {
            res.setContentType("text/html";
            ServletOutputStream out = res.getOutputStream();
            OutputStreamWriter ow = new OutputStreamWriter(out,"GB2312";
            ow.write("這是測試";
            ow.flush();
            ow.close();
            }

            問:如何設置Java WebServer的CLASSPATH,以包含用戶的class文件?
            答: 有兩種方法可以設置Java WebServer的CLASSPATH環境變量,以使用戶編寫的Servlet能夠調用用戶的class文件.
            將用戶的class文件放到 JavaWebServer_Dir/classes目錄下,在Java WebServer 啟動時,classes目錄被自動加入到CLASSPATH環境變量中了.
            修改httpd.nojre文件,將用戶class文件所在的路徑名加到CLASSPATH環境變量中.

            問: 為什么在Windows平臺上用Naming.lookup來獲取遠程RMI對象時會很慢?
            答: 機器的網絡設置不正確很可能會引起該問題的發生.
            RMI使用了Java網絡類,特別是java.net.InetAddress類,它將查詢TCP/IP的主機名, 包括IP地址到主機名的映射和主機名到IP地址的映射.在Windows平臺,這種查詢功能 是由本地的Windows Socket庫來實現的. 因此延時是發生在Windows庫中,而非RMI中.
            如果你的機器設置成使用DNS,問題通常是DNS服務器查不到主機名,你所發現的延時 是DNS查詢的延時. 請嘗試將RMI通信中涉及到的所有主機名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:
            IP地址 主機名
            如此設置應當可以明顯地減少查詢所花的時間.

          問: 編寫Java application時,如何設置proxy的信息,以便訪問外部網站?
            答: 若在java application中訪問外部網站,首先應設置proxy信息,樣例代碼如下:
            import java.util.properties;
            .....
            Properties sys = System.getProperties();
            sys.put("proxySet","true";
            sys.put("proxyHost","myHTTP.proxyserver.com";
            sys.put("proxyPort","80";
            System.setProperties(sys);
            u = new URL(website);
            connect = (HttpURLConnection)u.openConnection();
            .....

            問: Swing組件JList的列表數據修改了,如何通知JList改變顯示?
            答: JList組件有一個單獨的顯示模式ListModel來表示JList的顯示數據.
            JList創建以后,JList數據元素的值及數據元素的數量可以動態地改變.
            JList在它的數據模式ListModel中觀察數據的改變.因此,一個ListModel 的正確實現應當在每次數據發生改變時,通知事件的監聽者.

            當使用構造函數JList(Object[])創建一個JList的實例時,系統將自動 創建一個DefaultListModel的實例來存儲JList的顯示數據, 可以調用 DefaultListModel中定義的簡便方法來動態地修改JList的數據,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改數據的同時,將通知JList關于數據的改變.


            問: 在Java applet中如何實現一個模式對話框?

            答: 在Java applet中實現模式對話框的關鍵就是在創建一個對話框的時候 要為該對話框指定一個正確的父窗口.因為Applet是Panel類的子類,不 可以作為對話框的父窗口,所以首先要獲得applet所在的窗口,作為模式 對話框的父窗口. 樣例代碼如下:

            .....

            Dialog d = new Dialog( getParentWindow(comp),title);

            // comp為applet上的任意一個組件

            ....

            public void getParentWindow(Component compOnApplet,String title){

            Container c = compOnApplet.getParent();

            while (c != null) {

            if (c instanceof Frame)

            return (Frame) c;

            c = c.getParent();

            }

            return null;

            }


          問: 在Java applet中如何顯示另外一個HTML頁面?

            答: 通過java.applet.Applet.getAppletContext()方法可以獲得與該applet相關的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的瀏覽器顯示另外一個網頁.


            問: 用JDK實現的簽名applet,可否在Netscape或IE中運行?

            答: 用JDK實現的簽名applet,不可以在Netscape或IE中運行,但是可以在Hotjava瀏覽器中運行.

            不同的瀏覽器提供了不同的簽名applet機制,如Netscape提供了zigbert工具和 Capability API, 而IE則需要使用CAB文件. 但是,無論是Netscape工具產生的 簽名applet,還是用IE產生的簽名applet,都不可以在其它的瀏覽器中運行.

            如果要使JDK產生的簽名applet能夠在Netscape或IE中運行,解決方法是在 Netscape或IE中安裝Java Plugin,則用JDK實現的簽名applet就可以在這兩種 瀏覽器中運行.


            問: 用JNI技術可以從Java應用中調用C程序庫,但是如何使該C程序庫可以調用另外的C程序庫?

            答: 如果一個被Java調用的C程序庫C1仍需要調用另外一個C程序庫C2,那么在編譯C1的時候應當聯接程序庫C2,步驟如下(Solaris平臺):

            編寫調用C庫的Java文件,并編譯.

            javac java文件名

            產生C程序頭文件

            javah -jni java文件名(不帶后綴.java)

            編寫被Java調用的C程序C1.c,以及被C1調用的C2.c,并編譯.

            cc -G -Iinclude路徑名 C2.c -o libC2.so

            cc -G -Iinclude路徑名 -lC2 C1.c -o libC1.so


            設置環境變量

            setenv LD_LIBRARY_PATH libC1.so,libC2.so所在路徑

            :${LD_LIBRARY_PATH}

            運行java應用

          問:  在Java語言中,如何列出PC機文件系統中的所有驅動器名?

            答: 在Java 2版本中,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);

            InputStreamReader ir=newInputStreamReader(process.getInputStream());

            LineNumberReader input = new LineNumberReader (ir);

            String line;

            while ((line = input.readLine ()) != null)

            System.out.println(line);

            }

            catch (java.io.IOException e){

            System.err.println ("IOException " + e.getMessage());
            
            問: 如何產生簽名applet,以使applet能夠訪問本地資源?

            答: 在jdk1.1中,可以使用javakey命令來產生公鑰,私鑰,證書和簽名的jar文件,詳細資料 請參考: http://java.sun.com/security/usingJavakey.html而java 2對簽名機制做了比較大的改進,允許用戶更靈活地設置安全權限.Java 2提供了三個工具:keytool,policytool和jarsigner來實現簽名applet.例如,Joe編寫了一個簽名applet:SignedApplet.java,那么產生一個簡單的簽名applet的過程如下:

            //產生密鑰,密鑰別名為joe,口令為sign12,存放在密鑰庫joestore中

            keytool -genkey -alias joe -keypass sign12 -keystore joestore

            //將SignedApplet.class及相關文件打包成jar文件

            jar cvf SignedAppletDemo.jar

            //利用keytool生成的自簽名的證書產生簽名applet(jar文件)

            jarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe

            //將自簽名證書從keystore中輸出到文件

            keytool -export -keystore joestore -alias joe -file joe.cer

            而對于簽名applet的接受方Susan,需要通過如下步驟來安全地執行

            Joe編寫的簽名applet:

            //得到Joe的證書并將之讀入到密鑰庫中susanstore中

            keytool -import -alias joe -file joe.cer -keystore susanstore

            //運行policytool產生滿足Susan要求的policy文件

            policytool

            //用appletviewer運行之,或在瀏覽器中安裝java plugin來運行之.

            關于簽名applet在Java Plugin中的部署請參考以下網頁:

            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(int port)方法可以在某一特定端口創建名字服務,從而用戶無需再手工啟動rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于獲取名字服務.

          問: 使用類PrintJob進行打印操作時,應如何設置打印機名等打印屬性?

            答: 使用如下方法可以獲得PrintJob的實例用于控制打印操作:

            Toolkit.getPrintJob(Frame f, String jobtitle, Properties prop)

            那么對于打印屬性的設置可以通過對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,使該線程繼續運行,而在此之前,它也需要訪問這一系統資源,則將產生死鎖.

            因此,在Java 2中,比較流行的方式是定義線程的狀態變量,并使目標線程輪詢該狀態變量,當狀態為懸掛狀態時,可以使用wait()方法使之處于等待狀態.一旦需要該線程繼續運行,其它線程會調用notify()方法來通知它.

           問: 使用JDBC編程,應如何控制結果集ResultSet的指針,使之能夠上下移動,以及移動到結果集的第一行和最后一行?

            答: 在JDK1.1中,ResultSet類中只定義了next()方法支持數據指針的下移.但在Java 2中,ResultSet類增加了如下方法支持數據指針的移動,包括:

            ResultSet.first():將數據指針移到結果集的第一行

            ResultSet.last(): 將數據指針移到結果集的最后一行

            ResultSet.previous(): 將數據指針上移一行

            以上的方法定義在JDBC2.0的規范中,所有支持JDBC 2.0的JDBC驅動程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驅動程序廠商均有產品支持JDBC 2.0 .


            問: 哪幾種Web Server支持Servlet?如何使IIS支持Servlet?

            答: 目前,支持Servlet的服務器端產品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.

            此外,一些第三方廠商也開發了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能夠運行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.


            問: 如何在Java應用中將圖像存儲到圖像文件中?

            答: Java Advanced Imaging API(包含在Java Media API中)允許在Java應用中執行復雜的,高性能的圖像處理.JAI API提供了存儲圖像的能力.目前,JAI API支持以下幾種圖像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面給出了將圖像存儲到BMP文件的一段代碼:

            OutputStream os = new FileOutputStream(fileToWriteTo);

            BMPEncodeParam param = new BMPEncodeParam();

            ImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);

            enc.encode(img);

            os.close();

            有關存儲圖像文件的編程指南請參考以下網頁:

            http://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/


            問:

            如何用Java語言向串口讀寫數據? font>

            答:

            Sun公司的Java Communication API2.0可用于讀寫串口,它支持RS232串口和IEEE 1284 并口,提供了一種與平臺無關的串/并口通信機制.

          答: Java 2安裝后,需要設置PATH和JAVA_HOME環境變量.與JDK1.1不同的是:設置好JAVA_HOME環境變量后,JVM將自動搜索系統類庫以及用戶的當前路徑.
            Java 2環境變量的設置如下例所示:
            Solaris平臺: setenv JAVA_HOME Java2的安裝路徑
            setenv PATH $JAVA_HOME/bin:${PATH}
            Windows平臺: set JAVA_HOME=Java2的安裝路徑
            set PATH=$JAVA_HOMEbin;%PATH%

            問: 哪些Java集成開發工具支持Java 2?
            答: 目前流行的Java集成開發環境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.

            問: 如果在Netscape或IE瀏覽器中運行Java applet時出現了錯誤,如何確定錯誤范圍?
            答: 當java applet在瀏覽器中運行時,使用的是瀏覽器本身的缺省JVM.而不同瀏覽器對JDK的支持程度也不盡相同. 因此,在Netscape或IE瀏覽器中運行Java applet出現了錯誤,建議使用JDK提供的工具appletviewer或Sun公司的Hotjava瀏覽器來測試該applet,以確定錯誤的產生是與瀏覽器相關.
            如果applet在appletviewer或Hotjava中運行一切正常,則錯誤的產生是由于瀏覽 器不完全兼容JDK而引起的. 此時,解決方法可以是使用Hotjava瀏覽器或者安裝 Sun公司的Java Plugin.
            如果applet在Hotjava瀏覽器或appletviewer中運行即發生錯誤,則應當根據錯誤 提示檢查applet程序.

            問: 當用JDBC向數據庫中插入數據或從數據庫中提取數據時,為何有時中文字符會顯示為亂碼?
            答: 這個問題的實現通常與各個JDBC driver的實現有關. 目前大多數JDBC driver采用本地編碼格式來傳輸中文字符,例如中文字符"0x4175"會被轉成"0x41"和"0x75"進行傳輸. 因此我們需要對JDBC driver返回的字符以及要發給JDBC driver的字符進行轉換.
            當用JDBC driver向數據庫中插入數據時,需要先將Unicode轉成native code; 當 JDBC driver從數據庫中查詢數據時,則需要將native code轉換成Unicode. 下面給出了這兩種轉換的實現:
            String native2Unicode(String s) {
            if (s == null' 's.length() == 0) {
            return null;
            }
            byte[] buffer = new byte[s.length()];
            for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {
            c = s.charAt(i);
            byte []buf = (""+c).getBytes();
            buffer[j++] = (char)buf[0];
            buffer[j++] = (char)buf[1];
            }
            else {
            buffer[j++] = s.charAt(i);
            }
            }
            return new String(buffer, 0, j);
            }
            除使用以上兩個方法之外,有些JDBC driver如果對jdbc driver Manager設置了正確 的字符集屬性,以上2個方法就不需要了.

          問: 當用Servlet來處理http請求并產生返回的HTML頁面時,如何使HTML頁面中的中文字符能夠正常顯示?
            答: javax.servlet.http.HttpResponse類用于產生返回頁面.通過HttpResponse定義的方法getOutputStream()可以獲得ServletOutputStream的實例,這樣用戶就可以利用ServletOutputStream.write方法向輸出流中寫入返回頁面的內容. 但是ServletOutputStream使用的是缺省的編碼方式,如果要使返回頁面中的中文字 符能夠正常顯示,最好顯示地指定所用的字符編碼方式. 通常需要構造一個 OutputStreamWriter , 例程如下:
            public void doGet (HttpServletRequest req, HttpServletResponse res)
            throws ServletException, IOException
            {
            res.setContentType("text/html";
            ServletOutputStream out = res.getOutputStream();
            OutputStreamWriter ow = new OutputStreamWriter(out,"GB2312";
            ow.write("這是測試";
            ow.flush();
            ow.close();
            }

            問:如何設置Java WebServer的CLASSPATH,以包含用戶的class文件?
            答: 有兩種方法可以設置Java WebServer的CLASSPATH環境變量,以使用戶編寫的Servlet能夠調用用戶的class文件.
            將用戶的class文件放到 JavaWebServer_Dir/classes目錄下,在Java WebServer 啟動時,classes目錄被自動加入到CLASSPATH環境變量中了.
            修改httpd.nojre文件,將用戶class文件所在的路徑名加到CLASSPATH環境變量中.

            問: 為什么在Windows平臺上用Naming.lookup來獲取遠程RMI對象時會很慢?
            答: 機器的網絡設置不正確很可能會引起該問題的發生.
            RMI使用了Java網絡類,特別是java.net.InetAddress類,它將查詢TCP/IP的主機名, 包括IP地址到主機名的映射和主機名到IP地址的映射.在Windows平臺,這種查詢功能 是由本地的Windows Socket庫來實現的. 因此延時是發生在Windows庫中,而非RMI中.
            如果你的機器設置成使用DNS,問題通常是DNS服務器查不到主機名,你所發現的延時 是DNS查詢的延時. 請嘗試將RMI通信中涉及到的所有主機名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:
            IP地址 主機名
            如此設置應當可以明顯地減少查詢所花的時間.

          問: 編寫Java application時,如何設置proxy的信息,以便訪問外部網站?
            答: 若在java application中訪問外部網站,首先應設置proxy信息,樣例代碼如下:
            import java.util.properties;
            .....
            Properties sys = System.getProperties();
            sys.put("proxySet","true";
            sys.put("proxyHost","myHTTP.proxyserver.com";
            sys.put("proxyPort","80";
            System.setProperties(sys);
            u = new URL(website);
            connect = (HttpURLConnection)u.openConnection();
            .....

            問: Swing組件JList的列表數據修改了,如何通知JList改變顯示?
            答: JList組件有一個單獨的顯示模式ListModel來表示JList的顯示數據.
            JList創建以后,JList數據元素的值及數據元素的數量可以動態地改變.
            JList在它的數據模式ListModel中觀察數據的改變.因此,一個ListModel 的正確實現應當在每次數據發生改變時,通知事件的監聽者.

            當使用構造函數JList(Object[])創建一個JList的實例時,系統將自動 創建一個DefaultListModel的實例來存儲JList的顯示數據, 可以調用 DefaultListModel中定義的簡便方法來動態地修改JList的數據,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改數據的同時,將通知JList關于數據的改變.


            問: 在Java applet中如何實現一個模式對話框?

            答: 在Java applet中實現模式對話框的關鍵就是在創建一個對話框的時候 要為該對話框指定一個正確的父窗口.因為Applet是Panel類的子類,不 可以作為對話框的父窗口,所以首先要獲得applet所在的窗口,作為模式 對話框的父窗口. 樣例代碼如下:

            .....

            Dialog d = new Dialog( getParentWindow(comp),title);

            // comp為applet上的任意一個組件

            ....

            public void getParentWindow(Component compOnApplet,String title){

            Container c = compOnApplet.getParent();

            while (c != null) {

            if (c instanceof Frame)

            return (Frame) c;

            c = c.getParent();

            }

            return null;

            }


          問: 在Java applet中如何顯示另外一個HTML頁面?

            答: 通過java.applet.Applet.getAppletContext()方法可以獲得與該applet相關的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的瀏覽器顯示另外一個網頁.


            問: 用JDK實現的簽名applet,可否在Netscape或IE中運行?

            答: 用JDK實現的簽名applet,不可以在Netscape或IE中運行,但是可以在Hotjava瀏覽器中運行.

            不同的瀏覽器提供了不同的簽名applet機制,如Netscape提供了zigbert工具和 Capability API, 而IE則需要使用CAB文件. 但是,無論是Netscape工具產生的 簽名applet,還是用IE產生的簽名applet,都不可以在其它的瀏覽器中運行.

            如果要使JDK產生的簽名applet能夠在Netscape或IE中運行,解決方法是在 Netscape或IE中安裝Java Plugin,則用JDK實現的簽名applet就可以在這兩種 瀏覽器中運行.


            問: 用JNI技術可以從Java應用中調用C程序庫,但是如何使該C程序庫可以調用另外的C程序庫?

            答: 如果一個被Java調用的C程序庫C1仍需要調用另外一個C程序庫C2,那么在編譯C1的時候應當聯接程序庫C2,步驟如下(Solaris平臺):

            編寫調用C庫的Java文件,并編譯.

            javac java文件名

            產生C程序頭文件

            javah -jni java文件名(不帶后綴.java)

            編寫被Java調用的C程序C1.c,以及被C1調用的C2.c,并編譯.

            cc -G -Iinclude路徑名 C2.c -o libC2.so

            cc -G -Iinclude路徑名 -lC2 C1.c -o libC1.so


            設置環境變量

            setenv LD_LIBRARY_PATH libC1.so,libC2.so所在路徑

            :${LD_LIBRARY_PATH}

            運行java應用

          問:  在Java語言中,如何列出PC機文件系統中的所有驅動器名?

            答: 在Java 2版本中,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);

            InputStreamReader ir=newInputStreamReader(process.getInputStream());

            LineNumberReader input = new LineNumberReader (ir);

            String line;

            while ((line = input.readLine ()) != null)

            System.out.println(line);

            }

            catch (java.io.IOException e){

            System.err.println ("IOException " + e.getMessage());
            
            問: 如何產生簽名applet,以使applet能夠訪問本地資源?

            答: 在jdk1.1中,可以使用javakey命令來產生公鑰,私鑰,證書和簽名的jar文件,詳細資料 請參考: http://java.sun.com/security/usingJavakey.html而java 2對簽名機制做了比較大的改進,允許用戶更靈活地設置安全權限.Java 2提供了三個工具:keytool,policytool和jarsigner來實現簽名applet.例如,Joe編寫了一個簽名applet:SignedApplet.java,那么產生一個簡單的簽名applet的過程如下:

            //產生密鑰,密鑰別名為joe,口令為sign12,存放在密鑰庫joestore中

            keytool -genkey -alias joe -keypass sign12 -keystore joestore

            //將SignedApplet.class及相關文件打包成jar文件

            jar cvf SignedAppletDemo.jar

            //利用keytool生成的自簽名的證書產生簽名applet(jar文件)

            jarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe

            //將自簽名證書從keystore中輸出到文件

            keytool -export -keystore joestore -alias joe -file joe.cer

            而對于簽名applet的接受方Susan,需要通過如下步驟來安全地執行

            Joe編寫的簽名applet:

            //得到Joe的證書并將之讀入到密鑰庫中susanstore中

            keytool -import -alias joe -file joe.cer -keystore susanstore

            //運行policytool產生滿足Susan要求的policy文件

            policytool

            //用appletviewer運行之,或在瀏覽器中安裝java plugin來運行之.

            關于簽名applet在Java Plugin中的部署請參考以下網頁:

            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(int port)方法可以在某一特定端口創建名字服務,從而用戶無需再手工啟動rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于獲取名字服務.

          問: 使用類PrintJob進行打印操作時,應如何設置打印機名等打印屬性?

            答: 使用如下方法可以獲得PrintJob的實例用于控制打印操作:

            Toolkit.getPrintJob(Frame f, String jobtitle, Properties prop)

            那么對于打印屬性的設置可以通過對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,使該線程繼續運行,而在此之前,它也需要訪問這一系統資源,則將產生死鎖.

            因此,在Java 2中,比較流行的方式是定義線程的狀態變量,并使目標線程輪詢該狀態變量,當狀態為懸掛狀態時,可以使用wait()方法使之處于等待狀態.一旦需要該線程繼續運行,其它線程會調用notify()方法來通知它.

           問: 使用JDBC編程,應如何控制結果集ResultSet的指針,使之能夠上下移動,以及移動到結果集的第一行和最后一行?

            答: 在JDK1.1中,ResultSet類中只定義了next()方法支持數據指針的下移.但在Java 2中,ResultSet類增加了如下方法支持數據指針的移動,包括:

            ResultSet.first():將數據指針移到結果集的第一行

            ResultSet.last(): 將數據指針移到結果集的最后一行

            ResultSet.previous(): 將數據指針上移一行

            以上的方法定義在JDBC2.0的規范中,所有支持JDBC 2.0的JDBC驅動程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驅動程序廠商均有產品支持JDBC 2.0 .


            問: 哪幾種Web Server支持Servlet?如何使IIS支持Servlet?

            答: 目前,支持Servlet的服務器端產品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.

            此外,一些第三方廠商也開發了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能夠運行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.


            問: 如何在Java應用中將圖像存儲到圖像文件中?

            答: Java Advanced Imaging API(包含在Java Media API中)允許在Java應用中執行復雜的,高性能的圖像處理.JAI API提供了存儲圖像的能力.目前,JAI API支持以下幾種圖像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面給出了將圖像存儲到BMP文件的一段代碼:

            OutputStream os = new FileOutputStream(fileToWriteTo);

            BMPEncodeParam param = new BMPEncodeParam();

            ImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);

            enc.encode(img);

            os.close();

            有關存儲圖像文件的編程指南請參考以下網頁:

            http://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/


            問:

            如何用Java語言向串口讀寫數據? font>

            答:

            Sun公司的Java Communication API2.0可用于讀寫串口,它支持RS232串口和IEEE 1284 并口,提供了一種與平臺無關的串/并口通信機制.
          ]]>
          posted on 2005-09-20 14:57 Sung 閱讀(254) 評論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 肥东县| 资兴市| 桐柏县| 滕州市| 任丘市| 饶河县| 彭阳县| 彩票| 垣曲县| 额尔古纳市| 鄄城县| 泰州市| 富裕县| 邯郸县| 永兴县| 广宗县| 贵南县| 高雄市| 讷河市| 邻水| 西盟| 淮北市| 新野县| 神农架林区| 南丰县| 阆中市| 陈巴尔虎旗| 临朐县| 云浮市| 奉节县| 台东县| 托克托县| 曲阜市| 宜川县| 石门县| 高密市| 保德县| 隆德县| 潮安县| 枝江市| 吉林市|