1. 程式人生 > >應聘Java筆試時可能出現問題及其答案

應聘Java筆試時可能出現問題及其答案

應聘Java筆試時可能出現問題及其答案在尋找這些答案的過程中,我將相關答案記錄下來,就形成了以下這些東西。需要說明的是以下答案肯定有很多不完整甚至錯誤的地方,需要各位來更正與完善它,千萬不要扔我的雞蛋啊。希望本文能夠給即將奔赴筆試考場的同仁些許幫助,更希望更多的人加入到收集整理筆試題與完善答案的這些工作中來,為大家更好的獲得工作機會做一點貢獻。Java基礎方面: 1、作用域public,private,protected,以及不寫時的區別答:區別如下:作用域 當前類 同一package 子孫類 其他package public                                     √            

protected                                             ×friendly      √          √                    ×             ×private                 ×                    ×             ×不寫時預設為friendly 2ArrayListVector的區別,HashMapHashtable的區別答:就ArrayListVector主要從二方面來說. .同步性:Vector是執行緒安全的,也就是說是同步的,而ArrayList
是執行緒序不安全的,不是同步的.資料增長:當需要增長時,Vector預設增長為原來一培,而ArrayList卻是原來的一半HashMapHashTable主要從三方面來說。.歷史原因:Hashtable是基於陳舊的Dictionary類的,HashMapJava 1.2引進的Map介面的一個實現.同步性:Hashtable是執行緒安全的,也就是說是同步的,而HashMap是執行緒序不安全的,不是同步的.值:只有HashMap可以讓你將空值作為一個表的條目的keyvalue 3char型變數中能不能存貯一箇中文漢字?為什麼? 答:是能夠定義成為一箇中文的,因為java中以unicode
編碼,一個char16個位元組,所以放一箇中文是沒問題的4、多執行緒有幾種實現方法,都是什麼?同步有幾種實現方法,都是什麼? 答:多執行緒有兩種實現方法,分別是繼承Thread類與實現Runnable介面同步的實現方面有兩種,分別是synchronized,waitnotify 5、繼承時候類的執行順序問題,一般都是選擇題,問你將會打印出什麼? :父類:package test; public class FatherClass { public FatherClass() { System.out.println("FatherClass Create"); } } 子類: package test; import test.FatherClass; public class ChildClass extends FatherClass { public ChildClass() { System.out.println("ChildClass Create"); } public static void main(String[] args) { FatherClass fc = new FatherClass(); ChildClass cc = new ChildClass(); } } 輸出結果:C:\>java test.ChildClass FatherClass Create FatherClass Create ChildClass Create 6、內部類的實現方式? 答:示例程式碼如下:package test; public class OuterClass { private class InterClass { public InterClass() { System.out.println("InterClass Create"); } } public OuterClass() { InterClass ic = new InterClass(); System.out.println("OuterClass Create"); } public static void main(String[] args) { OuterClass oc = new OuterClass(); } } 輸出結果: C:\>java test/OuterClass InterClass Create OuterClass Create 再一個例題:public class OuterClass { private double d1 = 1.0; //insert code here } You need to insert an inner class declaration at line 3. Which two inner class declarations are valid?(Choose two.) A. class InnerOne{ public static double methoda() {return d1;} } B. public class InnerOne{ static double methoda() {return d1;} } C. private class InnerOne{ double methoda() {return d1;} } D. static class InnerOne{ protected double methoda() {return d1;} } E. abstract class InnerOne{ public abstract double methoda(); } 說明如下:.靜態內部類可以有靜態成員,而非靜態內部類則不能有靜態成員。 AB .靜態內部類的非靜態成員可以訪問外部類的靜態變數,而不可訪問外部類的非靜態變數;return d1 出錯。 D .非靜態內部類的非靜態成員可以訪問外部類的非靜態變數。 C 正確.答案為CE 7、垃圾回收機制,如何優化程式? 希望大家補上,謝謝8floatfloat f=3.4是否正確? :不正確。精度不準確,應該用強制型別轉換,如下所示:float f=(float)3.4 9、介紹JAVA中的Collection FrameWork(包括如何寫自己的資料結構)? 答:Collection FrameWork如下:Collection List │├LinkedList │├ArrayList │└Vector │ └Stack Set Map Hashtable HashMap WeakHashMap Collection是最基本的集合介面,一個Collection代表一組Object,即Collection的元素(ElementsMap提供keyvalue的對映10Java中異常處理機制,事件機制?11JAVA中的多形與繼承?希望大家補上,謝謝12、抽象類與介面?答:抽象類與介面都用於抽象,但是抽象類(JAVA)可以有自己的部分實現,而介面則完全是一個標識(同時有多重繼承的功能)13Java 的通訊程式設計,程式設計題(或問答),用JAVA SOCKET程式設計,讀伺服器幾個字元,再寫入本地顯示?:Server端程式:

package test;
import java.net.*;
import java.io.*;

public class Server
{
private ServerSocket ss;
private Socket socket;
private BufferedReader in;
private PrintWriter out;
public Server()
{
try
{
ss=new ServerSocket(10000);
while(true)
{
socket = ss.accept();
String RemoteIP = socket.getInetAddress().getHostAddress();
String RemotePort = ":"+socket.getLocalPort();
System.out.println("A client come in!IP:"+RemoteIP+RemotePort);
in = new BufferedReader(new

InputStreamReader(socket.getInputStream()));
String line = in.readLine();
System.out.println("Cleint send is :" + line);
out = new PrintWriter(socket.getOutputStream(),true);
out.println("Your Message Received!");
out.close();
in.close();
socket.close();
}
}catch (IOException e)
{
out.println("wrong");
}
}
public static void main(String[] args)
{
new Server();
}
};
Client端程式:
package test;
import java.io.*;
import java.net.*;

public class Client
{
Socket socket;
BufferedReader in;
PrintWriter out;
public Client()
{
try
{
System.out.println("Try to Connect to 127.0.0.1:10000");
socket = new Socket("127.0.0.1",10000);
System.out.println("The Server Connected!");
System.out.println("Please enter some Character:");
BufferedReader line = new BufferedReader(new

InputStreamReader(System.in));
out = new PrintWriter(socket.getOutputStream(),true);
out.println(line.readLine());
in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
System.out.println(in.readLine());
out.close();
in.close();
socket.close();
}catch(IOException e)
{
out.println("Wrong");
}
}
public static void main(String[] args)
{
new Client();
}
};

14、用JAVA實現一種排序,JAVA類實現序列化的方法(二種) 如在COLLECTION框架中,實現比較要實現什麼樣的介面?:用插入法進行排序程式碼如下package test; import java.util.*; class InsertSort { ArrayList al; public InsertSort(int num,int mod) { al = new ArrayList(num); Random rand = new Random(); System.out.println("The ArrayList Sort Before:"); for (int i=0;i<num ;i++ ) { al.add(new Integer(Math.abs(rand.nextInt()) % mod + 1)); System.out.println("al["+i+"]="+al.get(i)); } } public void SortIt() { Integer tempInt; int MaxSize=1; for(int i=1;i<al.size();i++) { tempInt = (Integer)al.remove(i); if(tempInt.intValue()>=((Integer)al.get(MaxSize-1)).intValue()) { al.add(MaxSize,tempInt); MaxSize++; System.out.println(al.toString()); } else { for (int j=0;j<MaxSize ;j++ ) { if (((Integer)al.get(j)).intValue()>=tempInt.intValue()) { al.add(j,tempInt); MaxSize++; System.out.println(al.toString()); break; } } } } System.out.println("The ArrayList Sort After:"); for(int i=0;i<al.size();i++) { System.out.println("al["+i+"]="+al.get(i)); } } public static void main(String[] args) { InsertSort is = new InsertSort(10,100); is.SortIt(); } } JAVA類實現序例化的方法是實現java.io.Serializable介面Collection框架中實現比較要實現Comparable 介面和 Comparator 介面15、程式設計:編寫一個擷取字串的函式,輸入為一個字串和位元組數,輸出為按位元組擷取的字串。 但是要保證漢字不被截半個,如“我ABC4,應該截為“我AB”,輸入“我ABCDEF”,6,應該輸出為“我ABC”而不是“我ABC+漢的半個”。答:程式碼如下:package test; class SplitString { String SplitStr; int SplitByte; public SplitString(String str,int bytes) { SplitStr=str; SplitByte=bytes; System.out.println("The String is:´"+SplitStr+"´;SplitBytes="+SplitByte); } public void SplitIt() { int loopCount; loopCount=(SplitStr.length()%SplitByte==0)?(SplitStr.length()/SplitByte):(SplitStr.length()/Split Byte+1); System.out.println("Will Split into "+loopCount); for (int i=1;i<=loopCount ;i++ ) { if (i==loopCount){ System.out.println(SplitStr.substring((i-1)*SplitByte,SplitStr.length())); } else { System.out.println(SplitStr.substring((i-1)*SplitByte,(i*SplitByte))); } } } public static void main(String[] args) { SplitString ss = new SplitString("testdddsaf中男大3443n中國43中國人0ewldfls=103",4); ss.SplitIt(); } } 16JAVA多執行緒程式設計。 JAVA寫一個多執行緒程式,如寫四個執行緒,二個加1,二個對一個變數減一,輸出。希望大家補上,謝謝17STRINGSTRINGBUFFER的區別。答:STRING的長度是不可變的,STRINGBUFFER的長度是可變的。如果你對字串中的內容經常進行操作,特別是內容要修改時,那麼使用StringBuffer,如果最後需要String,那麼使用StringBuffertoString()方法Jsp方面1jsp有哪些內建物件?作用分別是什麼? :JSP共有以下9種基本內建元件(可與ASP6種內部元件相對應):  request 使用者端請求,此請求會包含來自GET/POST請求的引數response 網頁傳回使用者端的迴應pageContext 網頁的屬性是在這裡管理session 與請求有關的會話期application servlet 正在執行的內容out 用來傳送回應的輸出config servlet的構架部件page JSP網頁本身exception 針對錯誤網頁,未捕捉的例外2jsp有哪些動作?作用分別是什麼? :JSP共有以下6種基本動作jsp:include:在頁面被請求的時候引入一個檔案。jsp:useBean:尋找或者例項化一個JavaBeanjsp:setProperty:設定JavaBean的屬性。jsp:getProperty:輸出某個JavaBean的屬性。jsp:forward:把請求轉到一個新的頁面。jsp:plugin:根據瀏覽器型別為Java外掛生成OBJECTEMBED標記3JSP中動態INCLUDE與靜態INCLUDE的區別?答:動態INCLUDEjsp:include動作實現<jsp:include page="included.jsp" flush="true" />它總是會檢查所含檔案中的變化,適合用於包含動態頁面,並且可以帶引數靜態INCLUDEinclude偽碼實現,定不會檢查所含檔案的變化,適用於包含靜態頁面<%@ include file="included.htm" %> 4、兩種跳轉方式分別是什麼?有什麼區別? 答:有兩種,分別為:<jsp:include page="included.jsp" flush="true"> <jsp:forward page= "nextpage.jsp"/> 前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是原來的頁面。執行完後還會回來,相當於函式呼叫。並且可以帶引數.後者完全轉向新頁面,不會再回來。相當於go to 語句。Servlet方面1、說一說Servlet的生命週期? :servlet有良好的生存期的定義,包括載入和例項化、初始化、處理請求以及服務結束。這個生存期由javax.servlet.Servlet介面的init,servicedestroy方法表達。2Servlet版本間(忘了問的是哪兩個版本了)的不同? 希望大家補上,謝謝3JAVA SERVLET APIforward() redirect()的區別?:前者僅是容器中控制權的轉向,在客戶端瀏覽器位址列中不會顯示出轉向後的地址;後者則是完全的跳轉,瀏覽器將會得到跳轉的地址,並重新發送請求連結。這樣,從瀏覽器的位址列中可以看到跳轉後的連結地址。所以,前者更加高效,在前者可以滿足需要時,儘量使用forward()方法,並且,這樣也有助於隱藏實際的連結。在有些情況下,比如,需要跳轉到一個其它伺服器上的資源,則必須使用sendRedirect()方法。4Servlet的基本架構public class ServletName extends HttpServlet { public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } } JdbcJdo方面1、可能會讓你寫一段JdbcOracle的程式,並實現資料查詢. :程式如下:package hello.ant; import java.sql.*; public class jdbc { String dbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl"; String theUser="admin"; String thePw="manager"; Connection c=null; Statement conn; ResultSet rs=null; public jdbc() { try{ Class.forName("oracle.jdbc.driver.OracleDriver").newInstance(); c = DriverManager.getConnection(dbUrl,theUser,thePw); conn=c.createStatement(); }catch(Exception e){ e.printStackTrace(); } } public boolean executeUpdate(String sql) { try { conn.executeUpdate(sql); return true; } catch (SQLException e) { e.printStackTrace(); return false; } } public ResultSet executeQuery(String sql) { rs=null; try { rs=conn.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); } return rs; } public void close() { try { conn.close(); c.close(); } catch (Exception e) { e.printStackTrace(); } } public static void main(String[] args) { ResultSet rs; jdbc conn = new jdbc(); rs=conn.executeQuery("select * from test"); try{ while (rs.next()) { System.out.println(rs.getString("id")); System.out.println(rs.getString("name")); } }catch(Exception e) { e.printStackTrace(); } } } 2Class.forName的作用?為什麼要用? 答:呼叫該訪問返回一個以字串指定類名的類的物件。3Jdo是什麼? :JDOJava物件持久化的新的規範,為java data object的簡稱,也是一個用於存取某種資料倉庫中的物件的標準化APIJDO提供了透明的物件儲存,因此對開發人員來說,儲存資料物件完全不需要額外的程式碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中時間和精力在業務邏輯上。另外,JDO很靈活,因為它可以在任何資料底層上執行。JDBC只是面向關係資料庫(RDBMS)JDO更通用,提供到任何資料底層的儲存功能,比如關係資料庫、檔案、XML以及物件資料庫(ODBMS)等等,使得應用可移植性更強。4、在ORACLE大資料量下的分頁解決方法。一般用擷取ID方法,還有是三層巢狀方法。:一種分頁方法<% int i=1; int numPages=14; String pages = request.getParameter("page") ; int currentPage = 1; currentPage=(pages==null)?(1):{Integer.parseInt(pages)} sql = "select count(*) from tables"; ResultSet rs = DBLink.executeQuery(sql) ; while(rs.next()) i = rs.getInt(1) ; int intPageCount=1; intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1); int nextPage ; int upPage; nextPage = currentPage+1; if (nextPage>=intPageCount) nextPage=intPageCount; upPage = currentPage-1; if (upPage<=1) upPage=1; rs.close(); sql="select * from tables"; rs=DBLink.executeQuery(sql); i=0; while((i<numPages*(currentPage-1))&&rs.next()){i++;} %> //輸出內容//輸出翻頁連線合計:<%=currentPage%>/<%=intPageCount%><a href="List.jsp?page=1">第一頁</a><a href="List.jsp?page=<%=upPage%>">上一頁</a> <% for(int j=1;j<=intPageCount;j++){ if(currentPage!=j){ %> <a href="list.jsp?page=<%=j%>">[<%=j%>]</a> <% }else{ out.println(j); } } %> <a href="List.jsp?page=<%=nextPage%>">下一頁</a><a href="List.jsp?page=<%=intPageCount%>">最後頁</a> Xml方面1xml有哪些解析技術?區別是什麼? :DOM,SAX,STAXDOM:處理大型檔案時其效能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構佔用的記憶體較多,而且DOM必須在解析檔案之前把整個文件裝入記憶體,適合對XML的隨機訪問SAX:不現於DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML檔案,不需要一次全部裝載整個檔案。當遇到像檔案開頭,文件結束,或者標籤開頭與標籤結束時,它會觸發一個事件,使用者通過在其回撥事件中寫入處理程式碼來處理XML檔案,適合對XML的順序訪問STAX:Streaming API for XML (StAX) 2、你在專案中用到了xml技術的哪些方面?如何實現的? :用到了資料存貯,資訊配置兩方面。在做資料交換平臺時,將不能資料來源的資料組裝成XML檔案,然後將XML檔案壓縮打包加密後通過網路傳送給接收者,接收解密與解壓縮後再同XML檔案中還原相關資訊進行處理。在做軟體配置時,利用XML可以很方便的進行,軟體的各種配置引數都存貯在XML檔案中。3、用jdom解析xml檔案時如何解決中文問題?如何解析? :看如下程式碼,用編碼方式加以解決package test; import java.io.*; public class DOMTest { private String inFile = "c:\\people.xml"; private String outFile = "c:\\people.xml"; public static void main(String args[]) { new DOMTest(); } public DOMTest() { try { javax.xml.parsers.DocumentBuilder builder = javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder(); org.w3c.dom.Document doc = builder.newDocument(); org.w3c.dom.Element root = doc.createElement("老師"); org.w3c.dom.Element wang = doc.createElement(""); org.w3c.dom.Element liu = doc.createElement(""); wang.appendChild(doc.createTextNode("我是王老師")); root.appendChild(wang); doc.appendChild(root); javax.xml.transform.Transformer transformer = javax.xml.transform.TransformerFactory.newInstance().newTransformer(); transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING, "gb2312"); transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT, "yes"); transformer.transform(new javax.xml.transform.dom.DOMSource(doc), new javax.xml.transform.stream.StreamResult(outFile)); } catch (Exception e) { System.out.println (e.getMessage()); } } } 4、程式設計用JAVA解析XML的方式. :SAX方式解析XMLXML檔案如下:<?xml version="1.0" encoding="gb2312"?> <person> <name>王小明</name> <college>資訊學院</college> <telephone>6258113</telephone> <notes>,1955年生,博士,95年調入海南大學</notes> </person> 事件回撥類SAXHandler.java import java.io.*; import java.util.Hashtable; import org.xml.sax.*; public class SAXHandler extends HandlerBase { private Hashtable table = new Hashtable(); private String currentElement = null; private String currentValue = null; public void setTable(Hashtable table) { this.table = table; } public Hashtable getTable() { return table; } public void startElement(String tag, AttributeList attrs) throws SAXException { currentElement = tag; } public void characters(char[] ch, int start, int length) throws SAXException { currentValue = new String(ch, start, length); } public void endElement(String name) throws SAXException { if (currentElement.equals(name)) table.put(currentElement, currentValue); } } JSP內容顯示原始碼,SaxXml.jsp: <HTML> <HEAD> <TITLE>剖析XML檔案people.xml</TITLE> </HEAD> <BODY> <%@ page errorPage="ErrPage.jsp" contentType="text/html;charset=GB2312" %> <%@ page import="java.io.*" %> <%@ page import="java.util.Hashtable" %> <%@ page import="org.w3c.dom.*" %> <%@ page import="org.xml.sax.*" %> <%@ page import="javax.xml.parsers.SAXParserFactory" %> <%@ page import="javax.xml.parsers.SAXParser" %> <%@ page import="SAXHandler" %> <% File file = new File("c:\\people.xml"); FileReader reader = new FileReader(file); Parser parser; SAXParserFactory spf = SAXParserFactory.newInstance(); SAXParser sp = spf.newSAXParser(); SAXHandler handler = new SAXHandler(); sp.parse(new InputSource(reader), handler); Hashtable hashTable = handler.getTable(); out.println("<TABLE BORDER=2><CAPTION>教師資訊表</CAPTION>"); out.println("<TR><TD>姓名</TD>" + "<TD>" + (String)hashTable.get(new String("name")) + "</TD></TR>"); out.println("<TR><TD>學院</TD>" + "<TD>" + (String)hashTable.get(new String("college"))+"</TD></TR>"); out.println("<TR><TD>電話</TD>" + "<TD>" + (String)hashTable.get(new String("telephone")) + "</TD></TR>"); out.println("<TR><TD>備註</TD>" + "<TD>" + (String)hashTable.get(new String("notes")) + "</TD></TR>"); out.println("</TABLE>"); %> </BODY> </HTML> EJB方面1EJB2.0有哪些內容?分別用在什麼場合? EJB2.0EJB1.1的區別? 答:規範內容包括Bean提供者,應用程式裝配者,EJB容器,EJB配置工具,EJB服務提供者,系統管理員。這裡面,EJB容器是EJB之所以能夠執行的核心。EJB容器管理著EJB的建立,撤消,啟用,去活,與資料庫的連線等等重要的核心工作。JSP,Servlet,EJB,JNDI,JDBC,JMS..... 2EJBJAVA BEAN的區別?:Java Bean 是可複用的元件,對Java Bean並沒有嚴格的規範,理論上講,任何一個Java類都可以是一個Bean。但通常情況下,由於Java Bean是被容器所建立(如Tomcat)的,所以Java Bean應具有一個無參的構造器,另外,通常Java Bean還要實現Serializable介面用於實現Bean的永續性。Java Bean實際上相當於微軟COM模型中的本地程序內COM元件,它是不能被跨程序訪問的。Enterprise Java Bean 相當於DCOM,即分散式元件。它是基於Java的遠端方法呼叫(RMI)技術的,所以EJB可以被遠端訪問(跨程序、跨計算機)。但EJB必須被佈署在諸如WebspereWebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB元件,而是通過其容器訪問。EJB容器是EJB元件的代理,EJB元件由容器所建立和管理。客戶通過容器來訪問真正的EJB元件。3EJB的基本架構:一個EJB包括三個部分: Remote Interface 介面的程式碼package Beans; import javax.ejb.EJBObject; import java.rmi.RemoteException; public interface Add extends EJBObject { //some method declare } Home Interface 介面的程式碼package Beans; import java.rmi.RemoteException; import jaax.ejb.CreateException; import javax.ejb.EJBHome; public interface AddHome extends EJBHome { //some method declare } EJB類的程式碼package Beans; import java.rmi.RemoteException; import javax.ejb.SessionBean; import javx.ejb.SessionContext; public class AddBean Implements SessionBean { //some method declare } J2EE,MVC方面1MVC的各個部分都有那些技術來實現?如何實現? :MVCModelViewController的簡寫。"Model" 代表的是應用的業務邏輯(通過JavaBeanEJB元件實現), "View" 是應用的表示面(由JSP頁面產生),"Controller" 是提供應用的處理過程控制(一般是一個Servlet),通過這種設計模型把應用邏輯,處理過程和顯示邏輯分成不同的元件實現。這些元件可以進行互動和重用。2、應用伺服器與WEB SERVER的區別?希望大家補上,謝謝3J2EE是什麼?:Je22Sun公司提出的多層(multi-diered),分散式(distributed),基於元件(component-base)的企業級應用模型(enterpriese application model).在這樣的一個應用系統中,可按照功能劃分為不同的元件,這些元件又可在不同計算機上,並且處於相應的層次(tier)中。所屬層次包括客戶層(clietn tier)元件,web層和元件,Business層和元件,企業資訊系統(EIS)層。4WEB SERVICE名詞解釋。JSWDL開發包的介紹。JAXPJAXM的解釋。SOAPUDDI,WSDL解釋。答:Web Service描述語言WSDL SOAP即簡單物件訪問協議(Simple Object Access Protocol),它是用於交換XML編碼資訊的輕量級協議。UDDI 的目的是為電子商務建立標準;UDDI是一套基於Web的、分散式的、為Web Service提供的、資訊註冊中心的實現標準規範,同時也包含一組使企業能將自身提供的Web Service註冊,以使別的企業能夠發現的訪問協議的實現標準。5BSCS的聯絡與區別。希望大家補上,謝謝6STRUTS的應用(STRUTS架構) 答:Struts是採用Java Servlet/JavaServer Pages技術,開發Web應用程式的開放原始碼的framework 採用Struts能開發出基於MVC(Model-View-Controller)設計模式的應用構架。 Struts有如下的主要功能:.包含一個controller servlet,能將使用者的請求傳送到相應的Action物件。.JSP自由tag庫,並且在controller servlet中提供關聯支援,幫助開發員建立互動式表單應用。.提供了一系列實用物件:XML處理、通過Java reflection APIs自動處理JavaBeans屬性、國際化的提示和訊息。設計模式方面1、開發中都用到了那些設計模式?用在什麼場合? 答:每個模式都描述了一個在我們的環境中不斷出現的問題,然後描述了該問題的解決方案的核心。通過這種方式,你可以無數次地使用那些已有的解決方案,無需在重複相同的工作。主要用到了MVC的設計模式。用來開發JSP/Servlet或者J2EE的相關應用。簡單工廠模式等。2UML方面答:標準建模語言UML。用例圖,靜態圖(包括類圖、物件圖和包圖),行為圖,互動圖(順序圖,合作圖),實現圖, JavaScript方面1、如何校驗數字型? var re=/^\d{1,8}$|\.\d{1,2}$/; var str=document.form1.all(i).value; var r=str.match(re); if (r==null) { sign=-4; break; } else{ document.form1.all(i).value=parseFloat(str); } CORBA方面1CORBA是什麼?用途是什麼? 答:CORBA 標準是公共物件請求代理結構(Common Object Request Broker Architecture),由物件管理組織 (Object Management Group,縮寫為 OMG)標準化。它的組成是介面定義語言(IDL), 語言繫結(binding:也譯為聯編)和允許應用程式間互操作的協議。 其目的為:用不同的程式設計語言書寫在不同的程序中執行為不同的作業系統開發LINUX方面1LINUX下執行緒,GDI類的解釋。答:LINUX實現的就是基於核心輕量級程序的"一對一"執行緒模型