版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
程序員面試之九陰真經談談final,finally,finalize的區(qū)別:?final:::修飾符(關鍵字)假如一個類被聲明為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為abstract的,又被聲明為final的。將變量或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變量必須在聲明時給定初值,而在以后的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載
finally:::再異常解決時提供finally塊來執(zhí)行任何清除操作。假如拋出一個異常,那么相匹配的catch子句就會執(zhí)行,然后控制就會進入finally塊(假如有的話)。
finalize:::方法名。Java技術允許使用finalize()方法在垃圾收集器將對象從內存中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在擬定這個對象沒有被引用時對這個對象調用的。它是在Object類中定義的,因此所有的類都繼承了它。子類覆蓋finalize()方法以整理系統資源或者執(zhí)行其他清理工作。finalize()方法是在垃圾收集器刪除對象之前對這個對象調用的。AnonymousInnerClass(匿名內部類)是否可以extends(繼承)其它類,是否可以implements(實現)interface(接口):?匿名的內部類是沒有名字的內部類。不能extends(繼承)其它類,但一個內部類可以作為一個接口,由另一個內部類實現。&和&&的區(qū)別:?&是位運算符。&&是布爾邏輯運算符。HashMap和Hashtable的區(qū)別:
都屬于Map接口的類,實現了將惟一鍵映射到特定的值上。?HashMap類沒有分類或者排序。它允許一個null鍵和多個null值。
Hashtable類似于HashMap,但是不允許null鍵和null值。它也比HashMap慢,由于它是同步的。Collection和Collections的區(qū)別:?Collections是個java.util下的類,它包具有各種有關集合操作的靜態(tài)方法。
Collection是個java.util下的接口,它是各種集合結構的父接口。GC是什么?為什么要有GC?(基礎):
GC是垃圾收集器。Java程序員不用緊張內存管理,由于垃圾收集器會自動進行管理。要請求垃圾收集,可以調用下面的方法之一:?System.gc()
Runtime.getRuntime().gc()。Strings=newString("xyz");創(chuàng)建了幾個StringObject:
兩個對象,一個是“xyx”,一個是指向“xyx”的引用對象s。Math.round(11.5)等於多少?Math.round(-11.5)等於多少:?Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11。shorts1=1;s1=s1+1;有什么錯?shorts1=1;s1+=1;有什么錯:
shorts1=1;s1=s1+1;有錯,s1是short型,s1+1是int型,不能顯式轉化為short型??尚薷臑閟1=(short)(s1+1)。shorts1=1;s1+=1對的。sleep()和wait()有什么區(qū)別:
sleep()方法是使線程停止一段時間的方法。在sleep時間間隔期滿后,線程不一定立即恢復執(zhí)行。這是由于在那個時刻,其它線程也許正在運營并且沒有被調度為放棄執(zhí)行,除非(a)“醒來”的線程具有更高的優(yōu)先級
(b)正在運營的線程由于其它因素而阻塞。
wait()是線程交互時,假如線程對一個同步對象x發(fā)出一個wait()調用,該線程會暫停執(zhí)行,被調對象進入等待狀態(tài),直到被喚醒或等待時間到。數組有沒有length()這個方法?String有沒有l(wèi)ength()這個方法:?數組沒有l(wèi)ength()這個方法,有l(wèi)ength的屬性。
String有有l(wèi)ength()這個方法。Overload和Override的區(qū)別。Overloaded的方法是否可以改變返回值的類型:
方法的重寫Overriding和重載Overloading是Java多態(tài)性的不同表現。重寫Overriding是父類與子類之間多態(tài)性的一種表現,重載Overloading是一個類中多態(tài)性的一種表現。假如在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫(Overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被“屏蔽”了。假如在一個類中定義了多個同名的方法,它們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。Set里的元素是不能反復的,那么用什么方法來區(qū)分反復與否呢?是用==還是equals()?它們有何區(qū)別:
Set里的元素是不能反復的,那么用iterator()方法來區(qū)分反復與否。equals()是判讀兩個Set是否相等。?equals()和==方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當兩個分離的對象的內容和類型相配的話,返回真值。給我一個你最常見到的runtimeexception:?ArithmeticException,ArrayStoreException,BufferOverflowException,BufferUnderflowException,CannotRedoException,CannotUndoException,ClassCastException,CMMException,ConcurrentModificat(yī)ionException,DOMException,EmptyStackException,IllegalArgumentException,IllegalMonitorStateException,IllegalPathStateException,IllegalStateException,ImagingOpException,IndexOutOfBoundsException,MissingResourceException,NegativeArraySizeException,NoSuchElementException,NullPointerException,ProfileDat(yī)aException,ProviderException,RasterFormatException,SecurityException,SystemException,UndeclaredThrowableException,UnmodifiableSetException,UnsupportedOperationException。error和exception有什么區(qū)別:?error表達恢復不是不也許但很困難的情況下的一種嚴重問題。比如說內存溢出。不也許指望程序能解決這樣的情況。
exception表達一種設計或實現問題。也就是說,它表達假如程序運營正常,從不會發(fā)生的情況。List,Set,Map是否繼承自Collection接口:
List,Set是。?Map不是。abstractclass和interface有什么區(qū)別:?聲明方法的存在而不去實現它的類被叫做抽象類(abstractclass),它用于要創(chuàng)建一個體現某些基本行為的類,并為該類聲明方法,但不能在該類中實現該類的情況。不能創(chuàng)建abstract類的實例。然而可以創(chuàng)建一個變量,其類型是一個抽象類,并讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態(tài)方法。Abstract類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。?接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過實現這樣的接口而獲得。接口中的所有方法都是抽象的,沒有一個有程序體。接口只可以定義staticfinal成員變量。接口的實現與子類相似,除了該實現類不能從接口定義中繼承行為。當類實現特殊接口時,它定義(即將程序體給予)所有這種接口的方法。然后,它可以在實現了該接口的類的任何對象上調用接口的方法。由于有抽象類,它允許使用接口名作為引用變量的類型。通常的動態(tài)聯編將生效。引用可以轉換到接口類型或從接口類型轉換,instanceof運算符可以用來決定某對象的類是否實現了接口。接口是否可繼承接口?抽象類是否可實現(implements)接口?抽象類是否可繼承實體類(concreteclass):?接口可以繼承接口。抽象類可以實現(implements)接口,抽象類是否可繼承實體類,但前提是實體類必須有明確的構造函數。啟動一個線程是用run()還是start():?啟動一個線程是調用start()方法,使線程所代表的虛擬解決機處在可運營狀態(tài),這意味著它可以由JVM調度并執(zhí)行。這并不意味著線程就會立即運營。run()方法可以產生必須退出的標志來停止一個線程。構造器Constructor是否可被override:?構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。try{}里有一個return語句,那么緊跟在這個try后的finally{}里的code會不會被執(zhí)行,什么時候被執(zhí)行,在return前還是后:
會執(zhí)行,在return前執(zhí)行。兩個對象值相同(x.equals(y)==true),但卻可有不同的hashcode,這句話對不對:
不對,有相同的hashcode。當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞:?是值傳遞。Java編程語言只由值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上:
switch(expr1)中,expr1是一個整數表達式。因此傳遞給switch和case語句的參數應當是int、short、char或者byte。long,string都不能作用于swtich。編程題:寫一個Singleton出來:?Singleton模式重要作用是保證在Java應用程序中,一個類Class只有一個實例存在。
一般Singleton模式通常有幾種種形式:
第一種形式:定義一個類,它的構造函數為private的,它有一個static的private的該類變量,在類初始化時實例話,通過一個public的getInstance方法獲取對它的引用,繼而調用其中的方法。
publicclassSingleton{
privateSingleton(){}
//在自己內部定義自己一個實例,是不是很奇怪?
//注意這是private只供內部調用
privatestat(yī)icSingletoninstance=newSingleton();
//這里提供了一個供外部訪問本class的靜態(tài)方法,可以直接訪問?publicstaticSingletongetInstance(){
returninstance;
}
}
?第二種形式:?publicclassSingleton{
privat(yī)estaticSingletoninstance=null;?publicstaticsynchronizedSingletongetInstance(){
//這個方法比上面有所改善,不用每次都進行生成對象,只是第一次
//使用時生成實例,提高了效率!
if(instance==null)
instance=newSingleton();?returninstance;}
}
其他形式:?定義一個類,它的構造函數為private的,所有方法為static的。
一般認為第一種形式要更加安全些。Hashtable和HashMap的區(qū)別:
Hashtable繼承自Dictionary類,而HashMap是Java1.2引進的Mapinterface的一個實現?HashMap允許將null作為一個entry的key或者value,而Hashtable不允許
尚有就是,HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。由于contains方法容易讓人引起誤解。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在?多個線程訪問Hashtable時,不需要自己為它的方法實現同步,而HashMap?就必須為之提供外同步。?Hashtable和HashMap采用的hash/rehash算法都大約同樣,所以性能不會有很大的差異作用域public,private,protected,以及不寫時的區(qū)別:
作用域當前類同一package子孫類其他package?public√√√√
protected√√√×?friendly√√××
private√×××
不寫時默認為friendly。ArrayList和Vector的區(qū)別,HashMap和Hashtable的區(qū)別:
答:就ArrayList與Vector重要從二方面來說.
一.同步性:Vector是線程安全的,也就是說是同步的,而ArrayList是線程序不安全的,不是同步的
二.數據增長:當需要增長時,Vector默認增長為本來一培,而ArrayList卻是本來的一半
就HashMap與HashTable重要從三方面來說。?一.歷史因素:Hashtable是基于陳舊的Dictionary類的,HashMap是Java1.2引進的Map接口的一個實現
二.同步性:Hashtable是線程安全的,也就是說是同步的,而HashMap是線程序不安全的,不是同步的?三.值:只有HashMap可以讓你將空值作為一個表的條目的key或value。char型變量中能不能存貯一個中文漢字?為什么:
答:是可以定義成為一個中文的,由于java中以unicode編碼,一個char占16個字節(jié),所以放一個中文是沒問題的。介紹JAVA中的CollectionFrameWork(涉及如何寫自己的數據結構):?答:CollectionFrameWork如下:
Collection
├List?│├LinkedList
│├ArrayList?│└Vector?│└Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMap
Collection是最基本的集合接口,一個Collection代表一組Object,即Collection的元素(Elements)?Map提供key到value的映射。jsp有哪些內置對象?作用分別是什么:?答:JSP共有以下9種基本內置組件(可與ASP的6種內部組件相相應):
request用戶端請求,此請求會包含來自GET/POST請求的參數?response網頁傳回用戶端的回應?pageContext網頁的屬性是在這里管理?session與請求有關的會話期
applicat(yī)ionservlet正在執(zhí)行的內容?out用來傳送回應的輸出
configservlet的構架部件?pageJSP網頁自身?exception針對錯誤網頁,未捕獲的例外。jsp有哪些動作?作用分別是什么:
答:JSP共有以下6種基本動作?jsp:include:在頁面被請求的時候引入一個文獻。
jsp:useBean:尋找或者實例化一個JavaBean。
jsp:setProperty:設立JavaBean的屬性。?jsp:getProperty:輸出某個JavaBean的屬性。?jsp:forward:把請求轉到一個新的頁面。
jsp:plugin:根據瀏覽器類型為Java插件生成OBJECT或EMBED標記。JSP中動態(tài)INCLUDE與靜態(tài)INCLUDE的區(qū)別:?答:動態(tài)INCLUDE用jsp:include動作實現
<jsp:includepage="included.jsp"flush="true"/>它總是會檢查所含文獻中的變化,適合用于包含動態(tài)頁面,并且可以帶參數
靜態(tài)INCLUDE用include偽碼實現,定不會檢查所含文獻的變化,合用于包含靜態(tài)頁面?<%@includefile="included.htm"%>。兩種跳轉方式分別是什么?有什么區(qū)別:
答:有兩種,分別為:?<jsp:includepage="included.jsp"flush="true">
<jsp:forwardpage="nextpage.jsp"/>
前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是本來的頁面。執(zhí)行完后還會回來,相稱于函數調用。并且可以帶參數.后者完全轉向新頁面,不會再回來。相稱于goto語句。說一說Servlet的生命周期:?答:servlet有良好的生存期的定義,涉及加載和實例化、初始化、解決請求以及服務結束。這個生存期由javax.servlet.Servlet接口的init,service和destroy方法表達。JAVASERVLETAPI中forward()與redirect()的區(qū)別:
答:前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向后的地址;后者則是完全的跳轉,瀏覽器將會得到跳轉的地址,并重新發(fā)送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉后的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,盡量使用forward()方法,并且,這樣也有助于隱藏實際的鏈接。在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用sendRedirect()方法。Servlet的基本架構:
publicclassServletNameextendsHttpServlet{
publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throws?ServletException,IOException{
}
publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throws
ServletException,IOException{
}?}也許會讓你寫一段Jdbc連Oracle的程序,并實現數據查詢:?答:程序如下:?packagehello.ant;
importjava.sql.*;?publicclassjdbc
{
StringdbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl";?StringtheUser="admin";?StringthePw="manager";
Connectionc=null;?Statementconn;
ResultSetrs=null;
publicjdbc()?{?try{
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();?c=DriverManager.getConnection(dbUrl,theUser,thePw);
conn=c.createStatement();
}catch(Exceptione){
e.printStackTrace();
}
}?publicbooleanexecuteUpdat(yī)e(Stringsql)
{
try?{
conn.executeUpdate(sql);
returntrue;?}?catch(SQLExceptione)?{?e.printStackTrace();?returnfalse;?}?}
publicResultSetexecuteQuery(Stringsql)
{?rs=null;
try?{
rs=conn.executeQuery(sql);?}?catch(SQLExceptione)
{
e.printStackTrace();?}?returnrs;?}
publicvoidclose()?{?try?{?conn.close();?c.close();
}
catch(Exceptione)?{?e.printStackTrace();
}?}
publicstaticvoidmain(String[]args)?{?ResultSetrs;
jdbcconn=newjdbc();
rs=conn.executeQuery("select*fromtest");
try{?while(rs.next())?{?System.out.println(rs.getString("id"));
System.out.println(rs.getString("name"));?}?}catch(Exceptione)
{?e.printStackTrace();
}
}
}Class.forName的作用?為什么要用:
答:調用該訪問返回一個以字符串指定類名的類的對象。Jdo是什么:?答:JDO是Java對象持久化的新的規(guī)范,為javadataobject的簡稱,也是一個用于存取某種數據倉庫中的對象的標準化API。JDO提供了透明的對象存儲,因此對開發(fā)人員來說,存儲數據對象完全不需要額外的代碼(如JDBCAPI的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發(fā)人員解脫出來,從而集中時間和精力在業(yè)務邏輯上。此外,JDO很靈活,由于它可以在任何數據底層上運營。JDBC只是面向關系數據庫(RDBMS)JDO更通用,提供到任何數據底層的存儲功能,比如關系數據庫、文獻、XML以及對象數據庫(ODBMS)等等,使得應用可移植性更強。xml有哪些解析技術?區(qū)別是什么:?答:有DOM,SAX,STAX等?DOM:解決大型文獻時其性能下降的非常厲害。這個問題是由DOM的樹結構所導致的,這種結構占用的內存較多,并且DOM必須在解析文獻之前把整個文檔裝入內存,適合對XML的隨機訪問SAX:不現于DOM,SAX是事件驅動型的XML解析方式。它順序讀?。豈L文獻,不需要一次所有裝載整個文獻。當碰到像文獻開頭,文檔結束,或者標簽開頭與標簽結束時,它會觸發(fā)一個事件,用戶通過在其回調事件中寫入解決代碼來解決XML文獻,適合對XML的順序訪問
STAX:StreamingAPIforXML(StAX)。你在項目中用到了xml技術的哪些方面?如何實現的:?答:用到了數據存貯,信息配置兩方面。在做數據互換平臺時,將不能數據源的數據組裝成XML文獻,然后將XML文獻壓縮打包加密后通過網絡傳送給接受者,接受解密與解壓縮后再同XML文獻中還原相關信息進行解決。在做軟件配置時,運用XML可以很方便的進行,軟件的各種配置參數都存貯在XML文獻中。用jdom解析xml文獻時如何解決中文問題?如何解析:?答:看如下代碼,用編碼方式加以解決?packagetest;
importjava.io.*;
publicclassDOMTest
{
privateStringinFile="c:\people.xml";
privat(yī)eStringoutFile="c:\people.xml";?publicstat(yī)icvoidmain(Stringargs[])
{?newDOMTest();
}?publicDOMTest()?{
try
{
javax.xml.parsers.DocumentBuilderbuilder=
javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();?org.w3c.dom.Documentdoc=builder.newDocument();?org.w3c.dom.Elementroot=doc.creat(yī)eElement("老師");
org.w3c.dom.Elementwang=doc.createElement("王");
org.w3c.dom.Elementliu=doc.createElement("劉");?wang.appendChild(doc.createTextNode("我是王老師"));?root.appendChild(wang);?doc.appendChild(root);
javax.xml.transform.Transformertransformer=?javax.xml.transform.TransformerFactory.newInstance().newTransformer();
transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING,"gb2312");?transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT,"yes");
?
?transformer.transform(newjavax.xml.transform.dom.DOMSource(doc),?new?
?javax.xml.transform.stream.StreamResult(outFile));?}
cat(yī)ch(Exceptione)
{?System.out.println(e.getMessage());?}?}?}編程用JAVA解析XML的方式:?答:用SAX方式解析XML,XML文獻如下:
<?xmlversion="1.0"encoding="gb2312"?>?<person>
<name>王小明</name>
<college>信息學院</college>?<telephone>6258113</telephone>?<notes>男,1955年生,博士,95年調入海南大學</notes>?</person>?事件回調類SAXHandler.java?importjava.io.*;
importjava.util.Hashtable;?importorg.xml.sax.*;
publicclassSAXHandlerextendsHandlerBase?{?privateHashtabletable=newHashtable();?privateStringcurrentElement=null;
privateStringcurrentValue=null;?publicvoidsetTable(Hashtabletable)
{?this.table=table;
}
publicHashtablegetTable()?{
returntable;?}
publicvoidstartElement(Stringtag,AttributeListattrs)?throwsSAXException
{
currentElement=tag;
}
publicvoidcharacters(char[]ch,intstart,intlength)?throwsSAXException
{
currentValue=newString(ch,start,length);
}?publicvoidendElement(Stringname)throwsSAXException
{
if(currentElement.equals(name))?table.put(currentElement,currentValue);
}?}?JSP內容顯示源碼,SaxXml.jsp:
<HTML>?<HEAD>
<TITLE>剖析XML文獻people.xml</TITLE>?</HEAD>
<BODY>?<%@pageerrorPage="ErrPage.jsp"?contentType="text/html;charset=GB2312"%>
<%@pageimport="java.io.*"%>?<%@pageimport="java.util.Hashtable"%>
<%@pageimport="org.w3c.dom.*"%>?<%@pageimport="org.xml.sax.*"%>
<%@pageimport="javax.xml.parsers.SAXParserFactory"%>?<%@pageimport="javax.xml.parsers.SAXParser"%>?<%@pageimport="SAXHandler"%>?<%?Filefile=newFile("c:\people.xml");
FileReaderreader=newFileReader(file);
Parserparser;
SAXParserFactoryspf=SAXParserFactory.newInstance();?SAXParsersp=spf.newSAXParser();?SAXHandlerhandler=newSAXHandler();?sp.parse(newInputSource(reader),handler);?HashtablehashTable=handler.getTable();
out.println("<TABLEBORDER=2><CAPTION>教師信息表</CAPTION>");
out.println("<TR><TD>姓名</TD>"+"<TD>"+?(String)hashTable.get(newString("name"))+"</TD></TR>");
out.println("<TR><TD>學院</TD>"+"<TD>"+
(String)hashTable.get(newString("college"))+"</TD></TR>");?out.println("<TR><TD>電話</TD>"+"<TD>"+?(String)hashTable.get(newString("telephone"))+"</TD></TR>");
out.println("<TR><TD>備注</TD>"+"<TD>"+
(String)hashTable.get(newString("notes"))+"</TD></TR>");
out.println("</TABLE>");
%>?</BODY>?</HTML>EJB與JAVABEAN的區(qū)別:?答:JavaBean是可復用的組件,對JavaBean并沒有嚴格的規(guī)范,理論上講,任何一個Java類都可以是一個Bean。但通常情況下,由于JavaBean是被容器所創(chuàng)建(如Tomcat)的,所以JavaBean應具有一個無參的構造器,此外,通常JavaBean還要實現Serializable接口用于實現Bean的持久性。JavaBean事實上相稱于微軟COM模型中的本地進程內COM組件,它是不能被跨進程訪問的。EnterpriseJavaBean相稱于DCOM,即分布式組件。它是基于Java的遠程方法調用(RMI)技術的,所以EJB可以被遠程訪問(跨進程、跨計算機)。但EJB必須被部署在諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB組件,而是通過其容器訪問。EJB容器是EJB組件的代理,EJB組件由容器所創(chuàng)建和管理。客戶通過容器來訪問真正的EJB組件。EJB的基本架構:
答:一個EJB涉及三個部分:
RemoteInterface接口的代碼?packageBeans;
importjavax.ejb.EJBObject;?importjava.rmi.RemoteException;?publicinterfaceAddextendsEJBObject
{?//somemethoddeclare
}?HomeInterface接口的代碼?packageBeans;?importjava.rmi.RemoteException;
importjaax.ejb.CreateException;
importjavax.ejb.EJBHome;?publierfaceAddHomeextendsEJBHome?{?//somemethoddeclare
}?EJB類的代碼?packageBeans;
importjava.rmi.RemoteException;?importjavax.ejb.SessionBean;?importjavx.ejb.SessionContext;?publicclassAddBeanImplementsSessionBean?{?//somemethoddeclare
}MVC的各個部分都有那些技術來實現?如何實現:?答:MVC是Model-View-Controller的簡寫。"Model"代表的是應用的業(yè)務邏輯(通過JavaBean,EJB組件實現),"View"是應用的表達面(由JSP頁面產生),"Controller"是提供應用的解決過程控制(一般是一個Servlet),通過這種設計模型把應用邏輯,解決過程和顯示邏輯提成不同的組件實現。這些組件可以進行交互和重用。J2EE是什么:
答:Je22是Sun公司提出的多層(multi-diered),分布式(distributed),基于組件(component-base)的公司級應用模型(enterprieseapplicationmodel).在這樣的一個應用系統中,可按照功能劃分為不同的組件,這些組件又可在不同計算機上,并且處在相應的層次(tier)中。所屬層次涉及客戶層(clietntier)組件,web層和組件,Business層和組件,公司信息系統(EIS)層。WEBSERVICE名詞解釋。JSWDL開發(fā)包的介紹。JAXP、JAXM的解釋。SOAP、UDDI,WSDL解釋:
答:WebService描述語言WSDL?SOAP即簡樸對象訪問協議(SimpleObjectAccessProtocol),它是用于互換XML編碼信息的輕量級協議。?UDDI的目的是為電子商務建立標準;UDDI是一套基于Web的、分布式的、為WebService提供的、信息注冊中心的實現標準規(guī)范,同時也包含一組使公司能將自身提供的WebService注冊,以使別的公司可以發(fā)現的訪問協議的實現標準。STRUTS的應用(如STRUTS架構):?答:Struts是采用JavaServlet/JavaServerPages技術,開發(fā)Web應用程序的開放源碼的framework。采用Struts能開發(fā)出基于MVC(Model-View-Controller)設計模式的應用構架。Struts有如下的重要功能:?一.包含一個controllerservlet,能將用戶的請求發(fā)送到相應的Action對象。
二.JSP自由tag庫,并且在controllerservlet中提供關聯支持,幫助開發(fā)員創(chuàng)建交互式表單應用。?三.提供了一系列實用對象:XML解決、通過JavareflectionAPIs自動解決JavaBeans屬性、國際化的提醒和消息。開發(fā)中都用到了那些設計模式?用在什么場合:
答:每個模式都描述了一個在我們的環(huán)境中不斷出現的問題,然后描述了該問題的解決方案的核心。通過這種方式,你可以無數次地使用那些已有的解決方案,無需在反復相同的工作。重要用到了MVC的設計模式。用來開發(fā)JSP/Servlet或者J2EE的相關應用。簡樸工廠模式等。存儲過程和函數的區(qū)別:
存儲過程是用戶定義的一系列sql語句的集合,涉及特定表或其它對象的任務,用戶可以調用存儲過程,而函數通常是數據庫已定義的方法,它接受參數并返回某種類型的值并且不涉及特定用戶表。事務是什么:
事務是作為一個邏輯單元執(zhí)行的一系列操作,一個邏輯工作單元必須有四個屬性,稱為ACID(原子性、一致性、隔離性和持久性)屬性,只有這樣才干成為一個事務:
原子性:?事務必須是原子工作單元;對于其數據修改,要么全都執(zhí)行,要么全都不執(zhí)行。
一致性:
事務在完畢時,必須使所有的數據都保持一致狀態(tài)。在相關數據庫中,所有規(guī)則都必須應用于事務的修改,以保持所有數據的完整性。事務結束時,所有的內部數據結構(如B樹索引或雙向鏈表)都必須是對的的。
隔離性:
由并發(fā)事務所作的修改必須與任何其它并發(fā)事務所作的修改隔離。事務查看數據時數據所處的狀態(tài),要么是另一并發(fā)事務修改它之前的狀態(tài),要么是另一事務修改它之后的狀態(tài),事務不會查看中間狀態(tài)的數據。這稱為可串行性,由于它可以重新裝載起始數據,并且重播一系列事務,以使數據結束時的狀態(tài)與原始事務執(zhí)行的狀態(tài)相同。?持久性:
事務完畢之后,它對于系統的影響是永久性的。該修改即使出現系統故障也將一直保持。游標的作用?如何知道游標已經到了最后:
游標用于定位結果集的行,通過判斷全局變量@@FETCH_STATUS可以判斷是否到了最后,通常此變量不等于0表達犯錯或到了最后。觸發(fā)器分為事前觸發(fā)和事后觸發(fā),這兩種觸發(fā)有和區(qū)別。語句級觸發(fā)和行級觸發(fā)有何區(qū)別:?事前觸發(fā)器運營于觸發(fā)事件發(fā)生之前,而事后觸發(fā)器運營于觸發(fā)事件發(fā)生之后。通常事前觸發(fā)器可以獲取事件之前和新的字段值。?語句級觸發(fā)器可以在語句執(zhí)行前或后執(zhí)行,而行級觸發(fā)在觸發(fā)器所影響的每一行觸發(fā)一次。bean實例的生命周期:?
對于Stat(yī)elessSessionBean、EntityBean、MessageDrivenBean一般存在緩沖池管理,而對于EntityBean和StatefullSessionBean存在Cache管理,通常包含創(chuàng)建實例,設立上下文、創(chuàng)建EJBObject(create)、業(yè)務方法調用、remove等過程,對于存在緩沖池管理的Bean,在creat(yī)e之后實例并不從內存清除,而是采用緩沖池調度機制不斷重用實例,而對于存在Cache管理的Bean則通過激活和去激活機制保持Bean的狀態(tài)并限制內存中實例數量。remote接口和home接口重要作用:?
remote接口定義了業(yè)務方法,用于EJB客戶端調用業(yè)務方法
home接口是EJB工廠用于創(chuàng)建和移除查找EJB實例??头苏{用EJB對象的幾個基本環(huán)節(jié):?一、
設立JNDI服務工廠以及JNDI服務地址系統屬性。
二、
查找Home接口。
三、
從Home接口調用Create方法創(chuàng)建Remote接口。?四、
通過Remote接口調用其業(yè)務方法。什么時候用assert:?斷言是一個包含布爾表達式的語句,在執(zhí)行這個語句時假定該表達式為true。假如表達式計算為false,那么系統會報告一個AssertionError。它用于調試目的:
assert(a>0);//throwsanAssertionErrorifa<=0
斷言可以有兩種形式:?assertExpression1;?assertExpression1:Expression2;
Expression1應當總是產生一個布爾值。
Expression2可以是得出一個值的任意表達式。這個值用于生成顯示更多調試信息的String消息。?斷言在默認情況下是禁用的。要在編譯時啟用斷言,需要使用source1.4標記:?javac-source1.4Test.java
要在運營時啟用斷言,可使用-enableassertions或者-ea標記。?要在運營時選擇禁用斷言,可使用-da或者-disableassertions標記。
要系統類中啟用斷言,可使用-esa或者-dsa標記。還可以在包的基礎上啟用或者禁用斷言。?可以在預計正常情況下不會到達的任何位置上放置斷言。斷言可以用于驗證傳遞給私有方法的參數。但是,斷言不應當用于驗證傳遞給公有方法的參數,由于不管是否啟用了斷言,公有方法都必須檢查其參數。但是,既可以在公有方法中,也可以在非公有方法中運用斷言測試后置條件。此外,斷言不應當以任何方式改變程序的狀態(tài)。是否可以繼承String類:
String類是final類故不可以繼承。面向對象的特性有哪些方面:抽象:抽象就是忽略一個主題中與當前目的無關的那些方面,以便更充足地注意與當前目的有關的方面。抽象并不打算了解所有問題,而只是選擇其中的一部分,暫時不用部分細節(jié)。抽象涉及兩個方面,一是過程抽象,二是數據抽象。繼承:繼承是一種聯結類的層次模型,并且允許和鼓勵類的重用,它提供了一種明確表述共性的方法。對象的一個新類可以從現有的類中派生,這個過程稱為類繼承。新類繼承了原始類的特性,新類稱為原始類的派生類(子類),而原始類稱為新類的基類(父類)。派生類可以從它的基類那里繼承方法和實例變量,并且類可以修改或增長新的方法使之更適合特殊的需要。封裝:封裝是把過程和數據包圍起來,對數據的訪問只能通過已定義的界面。面向對象計算始于這個基本概念,即現實世界可以被描繪成一系列完全自治、封裝的對象,這些對象通過一個受保護的接口訪問其他對象。多態(tài)性:多態(tài)性是指允許不同類的對象對同一消息作出響應。多態(tài)性涉及參數化多態(tài)性和包含多態(tài)性。多態(tài)性語言具有靈活、抽象、行為共享、代碼共享的優(yōu)勢,很好的解決了應用程序函數同名問題。String是最基本的數據類型嗎:基本數據類型涉及byte、int、char、long、float、double、boolean和short。java.lang.String類是final類型的,因此不可以繼承這個類、不能修改這個類。為了提高效率節(jié)省空間,我們應當用StringBuffer類。String和StringBuffer的區(qū)別:JAVA平臺提供了兩個類:String和StringBuffer,它們可以儲存和操作字符串,即包含多個字符的字符數據。這個String類提供了數值不可改變的字符串。而這個StringBuffer類提供的字符串進行修改。當你知道字符數據要改變的時候你就可以使用StringBuffer。典型地,你可以使用StringBuffers來動態(tài)構造字符數據。說出ArrayList,Vector,LinkedList的存儲性能和特性:ArrayList和Vector都是使用數組方式存儲數據,此數組元素數大于實際存儲的數據以便增長和插入元素,它們都允許直接按序號索引元素,但是插入元素要涉及數組元素移動等內存操作,所以索引數據快而插入數據慢,Vector由于使用了synchronized方法(線程安全),通常性能上較ArrayList差,而LinkedList使用雙向鏈表實現存儲,按序號索引數據需要進行前向或后向遍歷,但是插入數據時只需要記錄本項的前后項即可,所以插入速度較快。同步和異步有何異同,在什么情況下分別使用他們?舉例說明。假如數據將在線程間共享。例如正在寫的數據以后也許被另一個線程讀到,或者正在讀的數據也許已經被另一個線程寫過了,那么這些數據就是共享數據,必須進行同步存取。當應用程序在對象上調用了一個需要花費很長時間來執(zhí)行的方法,并且不希望讓程序等待方法的返回時,就應當使用異步編程,在很多情況下采用異步途徑往往更有效率。heap和stack有什么區(qū)別:棧是一種線形集合,其添加和刪除元素的操作應在同一段完畢。棧按照后進先出的方式進行解決。堆是棧的一個組成元素。EJB與JAVABEAN的區(qū)別:javaBean是可復用的組件,對JavaBean并沒有嚴格的規(guī)范,理論上講,任何一個Java類都可以是一個Bean。但通常情況下,由于JavaBean是被容器所創(chuàng)建(如Tomcat)的,所以JavaBean應具有一個無參的構造器,此外,通常JavaBean還要實現Serializable接口用于實現Bean的持久性。JavaBean事實上相稱于微軟COM模型中的本地進程內COM組件,它是不能被跨進程訪問的。EnterpriseJavaBean相稱于DCOM,即分布式組件。它是基于Java的遠程方法調用(RMI)技術的,所以EJB可以被遠程訪問(跨進程、跨計算機)。但EJB必須被部署在諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB組件,而是通過其容器訪問。EJB容器是EJB組件的代理,EJB組件由容器所創(chuàng)建和管理??蛻敉ㄟ^容器來訪問真正的EJB組件。StaticNestedClass和InnerClass的不同:StaticNestedClass是被聲明為靜態(tài)(static)的內部類,它可以不依賴于外部類實例被實例化。而通常的內部類需要在外部類實例化后才干實例化。Java的接口和C++的虛類的相同和不同處:由于Java不支持多繼承,而有也許某個類或對象要使用分別在幾個類或對象里面的方法或屬性,現有的單繼承機制就不能滿足規(guī)定。與繼承相比,接口有更高的靈活性,由于接口中沒有任何實現代碼。當一個類實現了接口以后,該類要實現接口里面所有的方法和屬性,并且接口里面的屬性在默認狀態(tài)下面都是publicstatic,所有方法默認情況下是public.一個類可以實現多個接口。你所知道的集合類都有哪些?重要方法:最常用的集合類是List和Map。List的具體實現涉及ArrayList和Vector,它們是可變大小的列表,比較適合構建、存儲和操作任何類型對象的元素列表。List合用于按數值索引訪問元素的情形。Map提供了一個更通用的元素存儲方法。Map集合類用于存儲元素對(稱作“鍵”和“值”),其中每個鍵映射到一個值。JSP的內置對象及方法:request表達HttpServletRequest對象。它包含了有關瀏覽器請求的信息,并且提供了幾個用于獲取cookie,header,和session數據的有用的方法,response表達HttpServletResponse對象,并提供了幾個用于設立送回瀏覽器的響應的方法(如cookies,頭信息等).out對象是javax.jsp.JspWriter的一個實例,并提供了幾個方法使你能用于向瀏覽器回送輸出結果。pageContext表達一個javax.servlet.jsp.PageContext對象。它是用于方便存取各種范圍的名字空間、servlet相關的對象的API,并且包裝了通用的servlet相關功能的方法。session表達一個請求的javax.servlet.http.HttpSession對象。Session可以存貯用戶的狀態(tài)信息applicaton表達一個javax.servle.ServletContext對象。這有助于查找有關servlet引擎和servlet環(huán)境的信息config表達一個javax.servlet.ServletConfig對象。該對象用于存取servlet實例的初始化參數。page表達從該頁面產生的一個servlet實例。線程的基本概念、線程的基本狀態(tài)以及狀態(tài)之間的關系:線程指在程序執(zhí)行過程中,可以執(zhí)行程序代碼的一個執(zhí)行單位,每個程序至少都有一個線程,也就是程序自身。Java中的線程有四種狀態(tài)分別是:運營、就緒、掛起、結束。JSP的常用指令:<%@pagelanguage=”java”contenType=”text/html;charset=gb2312”session=”true”buffer=”64kb”autoFlush=”true”isThreadSafe=”true”info=”text”errorPage=”error.jsp”isErrorPage=”true”isELIgnored=”true”pageEncoding=”gb2312”import=”java.sql.*”%>isErrorPage(是否能使用Exception對象),isELIgnored(是否忽略表達式)<%@includefile=”filename”%><%@taglibprefix=”c”uri=”http://……”%>四種會話跟蹤技術:cookie,url重寫,session,隱藏域。簡述邏輯操作(&,|,^)與條件操作(&&,||)的區(qū)別:區(qū)別重要答兩點:a.條件操作只能操作布爾型的,而邏輯操作不僅可以操作布爾型,并且可以操作數值型b.邏輯操作不會產生短路。?Request對象的重要方法:setAttribute(Str,Object):設立名字為name的request的參數值getAttribute(Stringname):返回由name指定的屬性值getAttributeNames():返回request對象所有屬性的名字集合,結果是一個枚舉的實例getCookies():返回客戶端的所有Cookie對象,結果是一個Cookie數組getCharacterEncoding():返回請求中的字符編碼方式getContentLength():返回請求的Body的長度getHeader(Stringname):獲得HTTP協議定義的文獻頭信息getHeaders(Stringname):返回指定名字的requestHeader的所有值,結果是一個枚舉的實例getHeaderNames():返回所以requestHeader的名字,結果是一個枚舉的實例getInputStream():返回請求的輸入流,用于獲得請求中的數據getMethod():獲得客戶端向服務器端傳送數據的方法getParameter(Stringname):獲得客戶端傳送給服務器端的有name指定的參數值getParameterNames():獲得客戶端傳送給服務器端的所有參數的名字,結果是一個枚舉的實例getParameterValues(Stringname):獲得有name指定的參數的所有值getProtocol():獲取客戶端向服務器端傳送數據所依據的協議名稱getQueryString():獲得查詢字符串getRequestURI():獲取發(fā)出請求字符串的客戶端地址getRemoteAddr():獲取客戶端的IP地址getRemoteHost():獲取客戶端的名字getSession([Booleancreate]):返回和請求相關SessiongetServerName():獲取服務器的名字getServletPath():獲取客戶端所請求的腳本文獻的途徑getServerPort():獲取服務器的端標語removeAttribute(Stringname):刪除請求中的一個屬性J2EE是技術還是平臺還是框架:J2EE自身是一個標準,一個為公司分布式應用的開發(fā)提供的標準平臺。J2EE也是一個框架,涉及JDBC、JNDI、RMI、JMS、EJB、JTA等技術。編寫java文獻的注意事項:在記事本中編寫java文獻,在保存時一定要把文獻名和擴展名用雙引號括起來,否則將默認保存為文本文獻,假如要保存的java文獻名為Program1.java,則在保存時在文獻名文本框中一定要輸入”Program1.java”。如何編譯java程序:單擊開始|運營命令,在命令行上輸入cmd,按回車鍵(在window98中輸入command,按回車鍵),即可打開一個命令窗口,將目錄轉換到編寫java源程序所在的目錄,輸入javacfilename.java如何執(zhí)行java程序:同樣在命令窗口中輸入javafilename。簡述synchronized和java.util.concurrent.locks.Lock的異同:重要相同點:Lock能完畢synchronized所實現的所有功能重要不同點:Lock有比synchronized更精確的線程語義和更好的性能。synchronized會自動釋放鎖,而Lock一定規(guī)定程序員手工釋放,并且必須在finally從句中釋放。EJB的角色和三個對象:一個完整的基于EJB的分布式計算結構由六個角色組成,這六個角色可以由不同的開發(fā)商提供,每個角色所作的工作必須遵循Sun公司提供的EJB規(guī)范,以保證彼此之間的兼容性。這六個角色分別是EJB組件開發(fā)者(EnterpriseBeanProvider)、應用組合者(ApplicationAssembler)、部署者(Deployer)、EJB服務器提供者(EJBServerProvider)、EJB容器提供者(EJBContainerProvider)、系統管理員(SystemAdministrat(yī)or)三個對象是Remote(Local)接口、Home(LocalHome)接口,Bean類EJB容器提供的服務:重要提供聲明周期管理、代碼產生、連續(xù)性管理、安全、事務管理、鎖和并發(fā)行管理等服務。EJB規(guī)范規(guī)定EJB中嚴禁的操作有哪些:不能操作線程和線程API(線程API指非線程對象的方法如notify,wait等),不能操作awt,不能實現服務器功能,不能對靜態(tài)屬生存取,不能使用IO操作直接存取文獻系統,不能加載本地庫.,不能將this作為變量和返回,不能循環(huán)調用。remote接口和home接口重要作用:remote接口定義了業(yè)務方法,用于EJB客戶端調用業(yè)務方法。home接口是EJB工廠用于創(chuàng)建和移除查找EJB實例bean實例的生命周期對于:StatelessSessionBean、EntityBean、MessageDrivenBean一般存在緩沖池管理,而對于EntityBean和StatefullSessionBean存在Cache管理,通常包含創(chuàng)建實例,設立上下文、創(chuàng)建EJBObject(create)、業(yè)務方法調用、remove等過程,對于存在緩沖池管理的Bean,在create之后實例并不從內存清除,而是采用緩沖池調度機制不斷重用實例,而對于存在Cache管理的Bean則通過激活和去激活機制保持Bean的狀態(tài)并限制內存中實例數量。EJB的激活機制:以StatefulSessionBean為例:其Cache大小決定了內存中可以同時存在的Bean實例的數量,根據MRU或NRU算法,實例在激活和去激活狀態(tài)之間遷移,激活機制是當客戶端調用某個EJB實例業(yè)務方法時,假如相應EJBObject發(fā)現自己沒有綁定相應的Bean實例則從其去激活Bean存儲中(通過序列化機制存儲實例)回復(激活)此實例。狀態(tài)變遷前會調用相應的ejbActive和ejbPassivate方法。EJB的幾種類型:會話(Session)Bean,實體(Entity)Bean消息驅動的(MessageDriven)Bean;會話Bean又可分為有狀態(tài)(Stateful)和無狀態(tài)(Stateless)兩種;實體Bean可分為Bean管理的連續(xù)性(BMP)和容器管理的連續(xù)性(CMP)兩種如何給weblogic指定大小的內存:在啟動Weblogic的腳本中(位于所在Domian相應服務器目錄下的startServerName),增長setMEM_ARGS=-Xms32m-Xmx200m,可以調整最小內存為32M,最大200M如何設定的weblogic的熱啟動模式(開發(fā)模式)與產品發(fā)布模式:可以在管理控制臺中修改相應服務器的啟動模式為開發(fā)或產品模式之一?;蛘咝薷姆盏膯游墨I或者commenv文獻,增長setPRODUCTION_MODE=true。如何啟動時不需輸入用戶名與密碼:修改服務啟動文獻,增長WLS_USER和WLS_PW項。也可以在boot.properties文獻中增長加密過的用戶名和密碼.在weblogic管理制臺中對一個應用域(或者說是一個網站,Domain)進行jms及ejb或連接池等相關信息進行配置后,實際保存在什么文獻中?保存在此Domain的config.xml文獻中,它是服務器的核心配置文獻。說說weblogic中一個Domain的缺省目錄結構?比如要將一個簡樸的helloWorld.jsp放入何目錄下,然的在瀏覽器上就可打入http://主機:端標語//helloword.jsp就可以看到運營結果了?又比如這其中用到了一個自己寫的javaBean該如何辦:Domain目錄\服務器目錄\applications,將應用目錄放在此目錄下將可以作為應用訪問,假如是Web應用,應用目錄需要滿足Web應用目錄規(guī)定,jsp文獻可以直接放在應用目錄中,Javabean需要放在應用目錄的WEB-INF目錄的classes目錄中,設立服務器的缺省應用將可以實現在瀏覽器上無需輸入應用名。在weblogic中發(fā)布ejb需涉及到哪些配置文獻:不同類型的EJB涉及的配置文獻不同,都涉及到的配置文獻涉及ejb-jar.xml,weblogic-ejb-jar.xmlCMP實體Bean一般還需要weblogic-cmp-rdbms-jar.xml如何在weblogic中進行ssl配置與客戶端的認證配置或說說j2ee(標準)進行ssl的配置:缺省安裝中使用DemoIdentity.jks和DemoTrust.jksKeyStore實現SSL,需要配置服務器使用EnableSSL,配置其端口,在產品模式下需要從CA獲取私有密鑰和數字證書,創(chuàng)建identity和trustkeystore,裝載獲得的密鑰和數字證書??梢耘渲么耍覵L連接是單向還是雙向的。如何查看在weblogic中已經發(fā)布的EJB:可以使用管理控制臺,在它的Deployment中可以查看所有已發(fā)布的EJBCORBA是什么?用途是什么:CORBA標準是公共對象請求代理結構(CommonObjectRequestBrokerArchitecture),由對象管理組織(ObjectManagementGroup,縮寫為OMG)標準化。它的組成是接口定義語言(IDL),語言綁定(binding:也譯為聯編)和允許應用程序間互操作的協議。其目的為:用不同的程序設計語言書寫在不同的進程中運營,為不同的操作系統開發(fā)。說說你所熟悉或聽說過的j2ee中的幾種常用模式?及對設計模式的一些見解:SessionFacadePattern:使用SessionBean訪問EntityBean;MessageFacadePattern:實現異步調用;EJBCommandPattern:使用CommandJavaBeans取代SessionBean,實現輕量級訪問;Dat(yī)aTransferObjectFactory:通過DTOFactory簡化EntityBean數據提供特性;GenericAttributeAccess:通過AttibuteAccess接口簡化EntityBean數據提供特性;BusinessInterface:通過遠程(本地)接口和Bean類實現相同接口規(guī)范業(yè)務邏輯一致性;EJB架構的設計好壞將直接影響系統的性能、可擴展性、可維護性、組件可重用性及開發(fā)效率。項目越復雜,項目隊伍越龐大則越能體現良好設計的重要性。說說在weblogic中開發(fā)消息Bean時的persistent與non-persisten的差別:persistent方式的MDB可以保證消息傳遞的可靠性,也就是假如EJB容器出現問題而JMS服務器仍然會將消息在此MDB可用的時候發(fā)送過來,而non-persistent方式的消息將被丟棄。常用的設計模式?說明工廠模式:Java中的23種設計模式:Factory(工廠模式),Builder(建造模式),FactoryMethod(工廠方法模式),Prototype(原始模型模式),Singleton(單例模式),Facade(門面模式),Adapter(適配器模式),Bridge(橋梁模式),Composite(合成模式),Decorator(裝飾模式),Flyweight(享元模式),Proxy(代理模式),Command(命令模式),Interpreter(解釋器模式),Visitor(訪問者模式),Iterator(迭代子模式),Mediator(調停者模式),Memento(備忘錄模式),Observer(觀測者模式),State(狀態(tài)模式),Strat(yī)egy(策略模式),TemplateMethod(模板方法模式),ChainOfResponsibleity(責任鏈模式)。工廠模式:工廠模式是一種經常被使用到的模式,根據工廠模式實現的類可以根據提供的數據生成一組類中某一個類的實例,通常這一組類有一個公共的抽象父類并且實現了相同的方法,但是這些方法針對不同的數據進行了不同的操作。一方面需要定義一個基類,該類的子類通過不同的方法實現了基類中的方法。然后需要定義一個工廠類,工廠類可以根據條件生成不同的子類實例。當得到子類的實例后,開發(fā)人員可以調用基類中的方法而不必考慮到底返回的是哪一個子類的實例。請對以下在J2EE中常用的名詞進行解釋(或簡樸描述):web容器:給處在其中的應用程序組件(JSP,SERVLET)提供一個環(huán)境,使JSP,SERVLET直接更容器中的環(huán)境變量接口交互,不必關注其它系統問題。重要有WEB服務器來實現。例如:TOMCAT,WEBLOGIC,WEBSPHERE等。該容器提供的接口嚴格遵守J2EE規(guī)范中的WEBAPPLICATION標準。我們把遵守以上標準的WEB服務器就叫做J2EE中的WEB容器。EJB容器:Enterprisejavabean容器。更具有行業(yè)領域特色。他提供應運營在其中的組件EJB各種管理功能。只要滿足J2EE規(guī)范的EJB放入該容器,立即就會被容器進行高效率的管理。并且可以通過現成的接口來獲得系統級別的服務。例如郵件服務、事務管理。JNDI:(JavaNaming&DirectoryInterface)JAVA命名目錄服務。重要提供的功能是:提供一個目錄系統,讓其它各地的應用程序在其上面留下自己的索引,從而滿足快速查找和定位分布式應用程序的功能。JMS:(Ja
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 租賃門面合同范例格式
- 烘焙業(yè)勞務合同范例
- 購銷合同范例水泥
- 水泵設備租賃合同范例
- 水果送貨合同范例
- 公益房屋租賃合同范例
- 推廣服務合同范例
- 天山股合同范例
- 值班合同范例
- 生意做工合同范例
- 2024北京海淀區(qū)初三(上)期末化學試卷及答案
- 廣東省陽江市江城區(qū)2023-2024學年部編版八年級歷史上學期期末試卷
- 《中藥膏方講座》課件
- 上消化道穿孔教學查房課件
- 暴發(fā)性心肌炎的治療及護理
- 現代農業(yè)產業(yè)園總體規(guī)劃方案
- 氣割廢鐵施工方案
- 道路危險貨物運輸車輛的安全檢查和隱患排查
- 2023-2024學年杭州市上城區(qū)數學六年級第一學期期末調研試題含答案
- 職稱評聘評委承諾書
- 游泳安全保障制度和措施
評論
0/150
提交評論