1. 程式人生 > >java經典面試題

java經典面試題

Java基礎方面:

0、作用域public,private,protected,以及不寫時的區別
答:區別如下:
作用域 當前類 同一package 子孫類 其他package
public √ √ √ √
protected √ √ √ ×
friendly √ √ × ×
private √ × × ×
不寫時預設為friendly

1。
java.lang.String類是final型別的,因此不可以繼承這個類、不能修改這個類。為了提高效率節省空間,我們應該用StringBuffer類

3、int 和 Integer 有什麼區別
Java 提供兩種不同的型別:引用型別和原始型別(或內建型別)。Int是java的原始資料型別,Integer是java為int提供的封裝類。Java為每個原始型別提供了封裝類。
原始型別封裝類
booleanBoolean
charCharacter
byteByte
shortShort
intInteger
longLong
floatFloat
doubleDouble
引 用型別和原始型別的行為完全不同,並且它們具有不同的語義。引用型別和原始型別具有不同的特徵和用法,它們包括:大小和速度問題,這種型別以哪種型別的數 據結構儲存,當引用型別和原始型別用作某個類的例項資料時所指定的預設值。物件引用例項變數的預設值為 null,而原始型別例項變數的預設值與它們的型別有關。

4、String 和StringBuffer的區別
JAVA 平臺提供了兩個類:String和StringBuffer,它們可以儲存和操作字串,即包含多個字元的字元資料。這個String類提供了數值不可改 變的字串。而這個StringBuffer類提供的字串進行修改。當你知道字元資料要改變的時候你就可以使用StringBuffer。典型地,你可 以使用StringBuffers來動態構造字元資料。

5、執行時異常與一般異常有何異同?
異常表示程式執行過程中可能出現的非正常狀態,執行時異常表示虛擬機器的通常操作中可能遇到的異常,是一種常見執行錯誤。java編譯器要求方法必須宣告丟擲可能發生的非執行時異常,但是並不要求必須宣告丟擲未被捕獲的執行時異常。

6、說出Servlet的生命週期,並說出Servlet和CGI的區別。
Servlet被伺服器例項化後,容器執行其init方法,請求到達時執行其service方法,service方法自動派遣執行與請求對應的doXXX方法(doGet,doPost)等,當伺服器決定將例項銷燬的時候呼叫其destroy方法。
與cgi的區別在於servlet處於伺服器程序中,它通過多執行緒方式執行其service方法,一個例項可以服務於多個請求,並且其例項一般不會銷燬,而CGI對每個請求都產生新的程序,服務完成後就銷燬,所以效率上低於servlet。

7、說出ArrayList,Vector, LinkedList的儲存效能和特性


ArrayList 和Vector都是使用陣列方式儲存資料,此陣列元素數大於實際儲存的資料以便增加和插入元素,它們都允許直接按序號索引元素,但是插入元素要涉及陣列元 素移動等記憶體操作,所以索引資料快而插入資料慢,Vector由於使用了synchronized方法(執行緒安全),通常效能上較ArrayList差, 而LinkedList使用雙向連結串列實現儲存,按序號索引資料需要進行前向或後向遍歷,但是插入資料時只需要記錄本項的前後項即可,所以插入速度較快。

8、EJB是基於哪些技術實現的?並說出SessionBean和EntityBean的區別,StatefulBean和StatelessBean的區別。
EJB包括Session Bean、Entity Bean、Message Driven Bean,基於JNDI、RMI、JAT等技術實現。
SessionBean在J2EE應用程式中被用來完成一些伺服器端的業務操作,例如訪問資料庫、呼叫其他EJB元件。EntityBean被用來代表應用系統中用到的資料。
對於客戶機,SessionBean是一種非永續性物件,它實現某些在伺服器上執行的業務邏輯。
對於客戶機,EntityBean是一種永續性物件,它代表一個儲存在永續性儲存器中的實體的物件檢視,或是一個由現有企業應用程式實現的實體。
Session Bean 還可以再細分為 Stateful Session Bean 與 Stateless Session Bean ,這兩種的 Session Bean都可以將系統邏輯放在 method之中執行,不同的是 Stateful Session Bean 可以記錄呼叫者的狀態,因此通常來說,一個使用者會有一個相對應的 Stateful Session Bean 的實體。Stateless Session Bean 雖然也是邏輯元件,但是他卻不負責記錄使用者狀態,也就是說當使用者呼叫 Stateless Session Bean 的時候,EJB Container 並不會找尋特定的 Stateless Session Bean 的實體來執行這個 method。換言之,很可能數個使用者在執行某個 Stateless Session Bean 的 methods 時,會是同一個 Bean 的 Instance 在執行。從記憶體方面來看, Stateful Session Bean 與 Stateless Session Bean 比較, Stateful Session Bean 會消耗 J2EE Server 較多的記憶體,然而 Stateful Session Bean 的優勢卻在於他可以維持使用者的狀態。

9、Collection 和 Collections的區別。
  Collection是集合類的上級介面,繼承與他的介面主要有Set 和List.
Collections是針對集合類的一個幫助類,他提供一系列靜態方法實現對各種集合的搜尋、排序、執行緒安全化等操作。

10、&和&&的區別。
&是位運算子,表示按位與運算,&&是邏輯運算子,表示邏輯與(and)。

11、HashMap和Hashtable的區別。
HashMap是Hashtable的輕量級實現(非執行緒安全的實現),他們都完成了Map介面,主要區別在於HashMap允許空(null)鍵值(key),由於非執行緒安全,效率上可能高於Hashtable。
HashMap允許將null作為一個entry的key或者value,而Hashtable不允許。
HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因為contains方法容易讓人引起誤解。
Hashtable繼承自Dictionary類,而HashMap是Java1.2引進的Map interface的一個實現。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多個執行緒訪問Hashtable時,不需要自己為它的方法實現同步,而HashMap 就必須為之提供外同步。
Hashtable和HashMap採用的hash/rehash演算法都大概一樣,所以效能不會有很大的差異。

12、final, finally, finalize的區別。
  final 用於宣告屬性,方法和類,分別表示屬性不可變,方法不可覆蓋,類不可繼承。
finally是異常處理語句結構的一部分,表示總是執行。
finalize是Object類的一個方法,在垃圾收集器執行的時候會呼叫被回收物件的此方法,可以覆蓋此方法提供垃圾收集時的其他資源回收,例如關閉檔案等。

13、sleep() 和 wait() 有什麼區別?
sleep是執行緒類(Thread)的方法,導致此執行緒暫停執行指定時間,給執行機會給其他執行緒,但是監控狀態依然保持,到時後會自動恢復。呼叫sleep不會釋放物件鎖。
wait是Object類的方法,對此物件呼叫wait方法導致本執行緒放棄物件鎖,進入等待此物件的等待鎖定池,只有針對此物件發出notify方法(或notifyAll)後本執行緒才進入物件鎖定池準備獲得物件鎖進入執行狀態。

14、Overload和Override的區別。Overloaded的方法是否可以改變返回值的型別?
方 法的重寫Overriding和過載Overloading是Java多型性的不同表現。重寫Overriding是父類與子類之間多型性的一種表現,重 載Overloading是一個類中多型性的一種表現。如果在子類中定義某方法與其父類有相同的名稱和引數,我們說該方法被重寫 (Overriding)。子類的物件使用這個方法時,將呼叫子類中的定義,對它而言,父類中的定義如同被"遮蔽"了。如果在一個類中定義了多個同名的方 法,它們或有不同的引數個數或有不同的引數型別,則稱為方法的過載(Overloading)。Overloaded的方法是可以改變返回值的型別。

15、error和exception有什麼區別?
error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說記憶體溢位。不可能指望程式能處理這樣的情況。
exception 表示一種設計或實現問題。也就是說,它表示如果程式執行正常,從不會發生的情況。

16、同步和非同步有何異同,在什麼情況下分別使用他們?舉例說明。
如果資料將線上程間共享。例如正在寫的資料以後可能被另一個執行緒讀到,或者正在讀的資料可能已經被另一個執行緒寫過了,那麼這些資料就是共享資料,必須進行同步存取。
當應用程式在物件上呼叫了一個需要花費很長時間來執行的方法,並且不希望讓程式等待方法的返回時,就應該使用非同步程式設計,在很多情況下采用非同步途徑往往更有效率。

17、abstract class和interface有什麼區別?
聲 明方法的存在而不去實現它的類被叫做抽象類(abstract class),它用於要建立一個體現某些基本行為的類,併為該類宣告方法,但不能在該類中實現該類的情況。不能建立abstract 類的例項。然而可以建立一個變數,其型別是一個抽象類,並讓它指向具體子類的一個例項。不能有抽象建構函式或抽象靜態方法。Abstract 類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。
接 口(interface)是抽象類的變體。在介面中,所有方法都是抽象的。多繼承性可通過實現這樣的介面而獲得。介面中的所有方法都是抽象的,沒有一個有 程式體。介面只可以定義static final成員變數。介面的實現與子類相似,除了該實現類不能從介面定義中繼承行為。當類實現特殊介面時,它定義(即將程式體給予)所有這種介面的方法。 然後,它可以在實現了該介面的類的任何物件上呼叫介面的方法。由於有抽象類,它允許使用介面名作為引用變數的型別。通常的動態聯編將生效。引用可以轉換到 介面型別或從介面型別轉換,instanceof 運算子可以用來決定某物件的類是否實現了介面。

18、heap和stack有什麼區別。
棧是一種線形集合,其新增和刪除元素的操作應在同一段完成。棧按照後進先出的方式進行處理。
堆是棧的一個組成元素

19、forward 和redirect的區別
forward是伺服器請求資源,伺服器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,然後把這些內容再發給瀏覽器,瀏覽器根本不知道伺服器傳送的內容是從哪兒來的,所以它的位址列中還是原來的地址。
redirect就是服務端根據邏輯,傳送一個狀態碼,告訴瀏覽器重新去請求那個地址,一般來說瀏覽器會用剛才請求的所有引數重新請求,所以session,request引數都可以獲取。

20、EJB與JAVA 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必須被佈署在 諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB元件,而是通過其容器訪問。EJB容器是EJB元件的代理, EJB元件由容器所建立和管理。客戶通過容器來訪問真正的EJB元件。

21、Static Nested Class 和 Inner Class的不同。
Static Nested Class是被宣告為靜態(static)的內部類,它可以不依賴於外部類例項被例項化。而通常的內部類需要在外部類例項化後才能例項化。
22、JSP中動態INCLUDE與靜態INCLUDE的區別?
動態INCLUDE用jsp:include動作實現 它總是會檢查所含檔案中的變化,適合用於包含動態頁面,並且可以帶引數。
靜態INCLUDE用include偽碼實現,定不會檢查所含檔案的變化,適用於包含靜態頁面

23、什麼時候用assert。
assertion (斷言)在軟體開發中是一種常用的除錯方式,很多開發語言中都支援這種機制。在實現中,assertion就是在程式中的一條語句,它對一個 boolean表示式進行檢查,一個正確程式必須保證這個boolean表示式的值為true;如果該值為false,說明程式已經處於不正確的狀態下, 系統將給出警告或退出。一般來說,assertion用於保證程式最基本、關鍵的正確性。assertion檢查通常在開發和測試時開啟。為了提高效能, 在軟體釋出後,assertion檢查通常是關閉的。

24、GC是什麼? 為什麼要有GC?
   GC是垃圾收集的意思(Gabage Collection),記憶體處理是程式設計人員容易出現問題的地方,忘記或者錯誤的記憶體回收會導致程式或系統的不穩定甚至崩潰,Java提供的GC功能可以 自動監測物件是否超過作用域從而達到自動回收記憶體的目的,Java語言沒有提供釋放已分配記憶體的顯示操作方法。

25、short s1 = 1; s1 = s1 + 1;有什麼錯? short s1 = 1; s1 += 1;有什麼錯?
short s1 = 1; s1 = s1 + 1; (s1+1運算結果是int型,需要強制轉換型別)
short s1 = 1; s1 += 1;(可以正確編譯)

26、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)==12
Math.round(-11.5)==-11
round方法返回與引數最接近的長整數,引數加1/2後求其floor.

27、String s = new String("xyz");建立了幾個String Object?
兩個

28、設計4個執行緒,其中兩個執行緒每次對j增加1,另外兩個執行緒對j每次減少1。寫出程式。
以下程式使用內部類實現執行緒,對j增減的時候沒有考慮順序問題。
public class ThreadTest1{
private int j;
public static void main(String args[]){
ThreadTest1 tt=new ThreadTest1();
Inc inc=tt.new Inc();
Dec dec=tt.new Dec();
for(int i=0;i<2;i++){
Thread t=new Thread(inc);
t.start();
t=new Thread(dec);
t.start();
}
}
private synchronized void inc(){
j++;
System.out.println(Thread.currentThread().getName()+"-inc:"+j);
}
private synchronized void dec(){
j--;
System.out.println(Thread.currentThread().getName()+"-dec:"+j);
}
class Inc implements Runnable{
public void run(){
for(int i=0;i<100;i++){
inc();
}
}
}
class Dec implements Runnable{
public void run(){
for(int i=0;i<100;i++){
dec();
}
}
}
}

29、Java有沒有goto?
java中的保留字,現在沒有在java中使用。

30、啟動一個執行緒是用run()還是start()?
啟動一個執行緒是呼叫start()方法,使執行緒所代表的虛擬處理機處於可執行狀態,這意味著它可以由JVM排程並執行。這並不意味著執行緒就會立即執行。run()方法可以產生必須退出的標誌來停止一個執行緒。

31、EJB包括(SessionBean,EntityBean)說出他們的生命週期,及如何管理事務的?
SessionBean: Stateless Session Bean 的生命週期是由容器決定的,當客戶機發出請求要建立一個Bean的例項時,EJB容器不一定要建立一個新的Bean的例項供客戶機呼叫,而是隨便找一個現 有的例項提供給客戶機。當客戶機第一次呼叫一個Stateful Session Bean 時,容器必須立即在伺服器中建立一個新的Bean例項,並關聯到客戶機上,以後此客戶機呼叫Stateful Session Bean 的方法時容器會把呼叫分派到與此客戶機相關聯的Bean例項。
EntityBean:Entity Beans能存活相對較長的時間,並且狀態是持續的。只要資料庫中的資料存在,Entity beans就一直存活。而不是按照應用程式或者服務程序來說的。即使EJB容器崩潰了,Entity beans也是存活的。Entity Beans生命週期能夠被容器或者 Beans自己管理。
EJB通過以下技術管理實務:物件管理組織(OMG)的物件實務服務(OTS),Sun Microsystems的Transaction Service(JTS)、Java Transaction API(JTA),開發組(X/Open)的XA介面。

32、應用伺服器有那些?
BEA WebLogic Server,IBM WebSphere Application Server,Oracle9i Application Server,jBoss,Tomcat

33、給我一個你最常見到的runtime exception。
ArithmeticException, ArrayStoreException, BufferOverflowException, BufferUnderflowException, CannotRedoException, CannotUndoException, ClassCastException, CMMException, ConcurrentModificationException, DOMException, EmptyStackException, IllegalArgumentException, IllegalMonitorStateException, IllegalPathStateException, IllegalStateException, ImagingOpException, IndexOutOfBoundsException, MissingResourceException, NegativeArraySizeException, NoSuchElementException, NullPointerException, ProfileDataException, ProviderException, RasterFormatException, SecurityException, SystemException, UndeclaredThrowableException, UnmodifiableSetException, UnsupportedOperationException

34、介面是否可繼承介面? 抽象類是否可實現(implements)介面? 抽象類是否可繼承實體類(concrete class)?
介面可以繼承介面。抽象類可以實現(implements)介面,抽象類是否可繼承實體類,但前提是實體類必須有明確的建構函式。

35、List, Set, Map是否繼承自Collection介面?
List,Set是,Map不是

36、說出資料連線池的工作機制是什麼?
J2EE 伺服器啟動時會建立一定數量的池連線,並一直維持不少於此數目的池連線。客戶端程式需要連線時,池驅動程式會返回一個未使用的池連線並將其表記為忙。如果 當前沒有空閒連線,池驅動程式就新建一定數量的連線,新建連線的數量有配置引數決定。當使用的池連線呼叫完成後,池驅動程式將此連線表記為空閒,其他呼叫 就可以使用這個連線。

37、abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized?
都不能

38、陣列有沒有length()這個方法? String有沒有length()這個方法?
陣列沒有length()這個方法,有length的屬性。String有有length()這個方法。

39、Set裡的元素是不能重複的,那麼用什麼方法來區分重複與否呢? 是用==還是equals()? 它們有何區別?
Set裡的元素是不能重複的,那麼用iterator()方法來區分重複與否。equals()是判讀兩個Set是否相等。
equals()和==方法決定引用值是否指向同一物件equals()在類中被覆蓋,為的是當兩個分離的物件的內容和型別相配的話,返回真值。

40、構造器Constructor是否可被override?
構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被過載Overloading。

41、是否可以繼承String類?
String類是final類故不可以繼承。

42、swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
switch(expr1)中,expr1是一個整數表示式。因此傳遞給 switch 和 case 語句的引數應該是 int、 short、 char 或者 byte。long,string 都不能作用於swtich。

43、try {}裡有一個return語句,那麼緊跟在這個try後的finally {}裡的code會不會被執行,什麼時候被執行,在return前還是後?
會執行,在return前執行。

44、程式設計題: 用最有效率的方法算出2乘以8等於幾?
2 << 3

45、兩個物件值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對?
不對,有相同的hash code。

46、當一個物件被當作引數傳遞到一個方法後,此方法可改變這個物件的屬性,並可返回變化後的結果,那麼這裡到底是值傳遞還是引用傳遞?
是值傳遞。Java 程式語言只有值傳遞引數。當一個物件例項作為一個引數被傳遞到方法中時,引數的值就是對該物件的引用。物件的內容可以在被呼叫的方法中改變,但物件的引用是永遠不會改變的。

47、當一個執行緒進入一個物件的一個synchronized方法後,其它執行緒是否可進入此物件的其它方法?
不能,一個物件的一個synchronized方法只能由一個執行緒訪問。

48、程式設計題: 寫一個Singleton出來。
Singleton模式主要作用是保證在Java應用程式中,一個類Class只有一個例項存在。
一般Singleton模式通常有幾種種形式:
第一種形式: 定義一個類,它的建構函式為private的,它有一個static的private的該類變數,在類初始化時例項話,通過一個public的getInstance方法獲取對它的引用,繼而呼叫其中的方法。
public class Singleton {
private Singleton(){}
   //在自己內部定義自己一個例項,是不是很奇怪?
   //注意這是private 只供內部呼叫
   private static Singleton instance = new Singleton();
   //這裡提供了一個供外部訪問本class的靜態方法,可以直接訪問  
   public static Singleton getInstance() {
     return instance;   
   }
}
第二種形式:
public class Singleton {
  private static Singleton instance = null;
  public static synchronized Singleton getInstance() {
  //這個方法比上面有所改進,不用每次都進行生成物件,只是第一次     
  //使用時生成例項,提高了效率!
  if (instance==null)
    instance=new Singleton();
return instance;   }
}
其他形式:
定義一個類,它的建構函式為private的,所有方法為static的。
一般認為第一種形式要更加安全些

49、Java的介面和C++的虛類的相同和不同處。
由 於Java不支援多繼承,而有可能某個類或物件要使用分別在幾個類或物件裡面的方法或屬性,現有的單繼承機制就不能滿足要求。與繼承相比,介面有更高的靈 活性,因為介面中沒有任何實現程式碼。當一個類實現了介面以後,該類要實現接口裡面所有的方法和屬性,並且接口裡面的屬性在預設狀態下面都是public static,所有方法預設情況下是public.一個類可以實現多個介面。

50、Java中的異常處理機制的簡單原理和應用。
當JAVA 程式違反了JAVA的語義規則時,JAVA虛擬機器就會將發生的錯誤表示為一個異常。違反語義規則包括2種情況。一種是JAVA類庫內建的語義檢查。例如數 組下標越界,會引發IndexOutOfBoundsException;訪問null的物件時會引發NullPointerException。另一種 情況就是JAVA允許程式設計師擴充套件這種語義檢查,程式設計師可以建立自己的異常,並自由選擇在何時用throw關鍵字引發異常。所有的異常都是 java.lang.Thowable的子類。

51、垃圾回收的優點和原理。並考慮2種回收機制。
Java 語言中一個顯著的特點就是引入了垃圾回收機制,使c++程式設計師最頭疼的記憶體管理的問題迎刃而解,它使得Java程式設計師在編寫程式的時候不再需要考慮記憶體管 理。由於有個垃圾回收機制,Java中的物件不再有"作用域"的概念,只有物件的引用才有"作用域"。垃圾回收可以有效的防止記憶體洩露,有效的使用可以使 用的記憶體。垃圾回收器通常是作為一個單獨的低級別的執行緒執行,不可預知的情況下對記憶體堆中已經死亡的或者長時間沒有使用的物件進行清楚和回收,程式設計師不能 實時的呼叫垃圾回收器對某個物件或所有物件進行垃圾回收。回收機制有分代複製垃圾回收和標記垃圾回收,增量垃圾回收。

52、請說出你所知道的執行緒同步的方法。
wait():使一個執行緒處於等待狀態,並且釋放所持有的物件的lock。
sleep():使一個正在執行的執行緒處於睡眠狀態,是一個靜態方法,呼叫此方法要捕捉InterruptedException異常。
notify():喚醒一個處於等待狀態的執行緒,注意的是在呼叫此方法的時候,並不能確切的喚醒某一個等待狀態的執行緒,而是由JVM確定喚醒哪個執行緒,而且不是按優先順序。
Allnotity():喚醒所有處入等待狀態的執行緒,注意並不是給所有喚醒執行緒一個物件的鎖,而是讓它們競爭。

53、你所知道的集合類都有哪些?主要方法?
最常用的集合類是 List 和 Map。 List 的具體實現包括 ArrayList 和 Vector,它們是可變大小的列表,比較適合構建、儲存和操作任何型別物件的元素列表。 List 適用於按數值索引訪問元素的情形。
Map 提供了一個更通用的元素儲存方法。 Map 集合類用於儲存元素對(稱作"鍵"和"值"),其中每個鍵對映到一個值。

54、描述一下JVM載入class檔案的原理機制?
JVM中類的裝載是由ClassLoader和它的子類來實現的,Java ClassLoader 是一個重要的Java執行時系統元件。它負責在執行時查詢和裝入類檔案的類。

55char型變數中能不能存貯一箇中文漢字?為什麼?
能夠定義成為一箇中文的,因為java中以unicode編碼,一個char佔16個位元組,所以放一箇中文是沒問題的

56、多執行緒有幾種實現方法,都是什麼?同步有幾種實現方法,都是什麼?
多執行緒有兩種實現方法,分別是繼承Thread類與實現Runnable介面
同步的實現方面有兩種,分別是synchronized,wait與notify

57JSP的內建物件及方法。
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可以存貯使用者的狀態資訊
applicaton 表示一個javax.servle.ServletContext物件。這有助於查詢有關servlet引擎和servlet環境的資訊
config表示一個javax.servlet.ServletConfig物件。該物件用於存取servlet例項的初始化引數。
page表示從該頁面產生的一個servlet例項

58、執行緒的基本概念、執行緒的基本狀態以及狀態之間的關係
執行緒指在程式執行過程中,能夠執行程式程式碼的一個執行單位,每個程式至少都有一個執行緒,也就是程式本身。
Java中的執行緒有四種狀態分別是:執行、就緒、掛起、結束。

59JSP的常用指令

isErrorPage(是否能使用Exception物件),isELIgnored(是否忽略表示式)

" rel="nofollow" target="_blank">http://......"%>

60、什麼情況下呼叫doGet()doPost()
Jsp頁面中的form標籤裡的method屬性為get時呼叫doGet(),為post時呼叫doPost()。

61servlet的生命週期
web容器載入servlet,生命週期開始。通過呼叫servlet的init()方法進行servlet的初始化。通過呼叫service()方法實現,根據請求的不同調用不同的do***()方法。結束服務,web容器呼叫servlet的destroy()方法。

62、如何現實servlet的單執行緒模式

63、頁面間物件傳遞的方法
request,session,application,cookie等

64JSPServlet有哪些相同點和不同點,他們之間的聯絡是什麼?
JSP 是Servlet技術的擴充套件,本質上是Servlet的簡易方式,更強調應用的外表表達。JSP編譯後是"類servlet"。Servlet和JSP最 主要的不同點在於,Servlet的應用邏輯是在Java檔案中,並且完全從表示層中的HTML裡分離開來。而JSP的情況是Java和HTML可以組合 成一個副檔名為.jsp的檔案。JSP側重於檢視,Servlet主要用於控制邏輯。

65、四種會話跟蹤技術
會話作用域ServletsJSP 頁面描述
page否是代表與一個頁面相關的物件和屬性。一個頁面由一個編譯好的 Java servlet 類(可以帶有任何的 include 指令,但是沒有 include 動作)表示。這既包括 servlet 又包括被編譯成 servlet 的 JSP 頁面
request是是代表與 Web 客戶機發出的一個請求相關的物件和屬性。一個請求可能跨越多個頁面,涉及多個 Web 元件(由於 forward 指令和 include 動作的關係)
session是是代表與用於某個 Web 客戶機的一個使用者體驗相關的物件和屬性。一個 Web 會話可以也經常會跨越多個客戶機請求
application是是代表與整個 Web 應用程式相關的物件和屬性。這實質上是跨越整個 Web 應用程式,包括多個頁面、請求和會話的一個全域性作用域

66Request物件的主要方法:
setAttribute(String name,Object):設定名字為name的request的引數值
getAttribute(String name):返回由name指定的屬性值
getAttributeNames():返回request物件所有屬性的名字集合,結果是一個列舉的例項
getCookies():返回客戶端的所有Cookie物件,結果是一個Cookie陣列
getCharacterEncoding():返回請求中的字元編碼方式
getContentLength():返回請求的Body的長度
getHeader(String name):獲得HTTP協議定義的檔案頭資訊
getHeaders(String name):返回指定名字的request Header的所有值,結果是一個列舉的例項
getHeaderNames():返回所以request Header的名字,結果是一個列舉的例項
getInputStream():返回請求的輸入流,用於獲得請求中的資料
getMethod():獲得客戶端向伺服器端傳送資料的方法
getParameter(String name):獲得客戶端傳送給伺服器端的有name指定的引數值
getParameterNames():獲得客戶端傳送給伺服器端的所有引數的名字,結果是一個列舉的例項
getParameterValues(String name):獲得有name指定的引數的所有值
getProtocol():獲取客戶端向伺服器端傳送資料所依據的協議名稱
getQueryString():獲得查詢字串
getRequestURI():獲取發出請求字串的客戶端地址
getRemoteAddr():獲取客戶端的IP地址
getRemoteHost():獲取客戶端的名字
getSession([Boolean create]):返回和請求相關Session
getServerName():獲取伺服器的名字
getServletPath():獲取客戶端所請求的指令碼檔案的路徑
getServerPort():獲取伺服器的埠號
removeAttribute(String name):刪除請求中的一個屬性

67J2EE是技術還是平臺還是框架?
J2EE本身是一個標準,一個為企業分散式應用的開發提供的標準平臺。
J2EE也是一個框架,包括JDBC、JNDI、RMI、JMS、EJB、JTA等技術。

68、我們在web應用開發過程中經常遇到輸出某種編碼的字元,如iso8859-1等,如何輸出一個某種編碼的字串?
Public String translate (String str) {
String tempStr = "";
try {
tempStr = new String(str.getBytes("ISO-8859-1"), "GBK");
tempStr = tempStr.trim();
}
catch (Exception e) {
System.err.println(e.getMessage());
}
return tempStr;
}

69、簡述邏輯操作(&,|,^)與條件操作(&&,||)的區別。
區別主要答兩點:a.條件操作只能操作布林型的,而邏輯操作不僅可以操作布林型,而且可以運算元值型
b.邏輯操作不會產生短路

70XML文件定義有幾種形式?它們之間有何本質區別?解析XML文件有哪幾種方式?
a: 兩種形式 dtd schema
b: 本質區別:schema本身是xml的,可以被XML解析器解析(這也是從DTD上發展schema的根本目的)
c:有DOM,SAX,STAX等
DOM:處理大型檔案時其效能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構佔用的記憶體較多,而且DOM必須在解析檔案之前把整個文件裝入記憶體,適合對XML的隨機訪問
SAX:不現於DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML檔案,不需要一次全部裝載整個檔案。當遇到像檔案開頭,文件結束,或者標籤開頭與標籤結束時,它會觸發一個事件,使用者通過在其回撥事件中寫入處理程式碼來處理XML檔案,適合對XML的順序訪問
STAX:Streaming API for XML (StAX)

xml文件有兩種定義方法:
dtd:資料型別定義(data type definition),用以描述XML文件的文件結構,是早期的XML文件定義形式。
schema:其本身是基於XML語言編寫的,在型別和語法上的限定能力比dtd強,處理也比較方便,因為此正逐漸代替dtd成為新的模式定義語言。

71、簡述synchronizedjava.util.concurrent.locks.Lock的異同
主要相同點:Lock能完成synchronized所實現的所有功能
主要不同點:Lock有比synchronized更精確的執行緒語義和更好的效能。synchronized會自動釋放鎖,而Lock一定要求程式設計師手工釋放,並且必須在finally從句中釋放。

72EJB的角色和三個物件
一 個完整的基於EJB的分散式計算結構由六個角色組成,這六個角色可以由不同的開發商提供,每個角色所作的工作必須遵循Sun公司提供的EJB規範,以保證 彼此之間的相容性。這六個角色分別是EJB元件開發者(Enterprise Bean Provider) 、應用組合者(Application Assembler)、部署者(Deployer)、EJB 伺服器提供者(EJB Server Provider)、EJB 容器提供者(EJB Container Provider)、系統管理員(System Administrator)
三個物件是Remote(Local)介面、Home(LocalHome)介面,Bean類

73EJB容器提供的服務
主要提供宣告週期管理、程式碼產生、持續性管理、安全、事務管理、鎖和併發行管理等服務。

74EJB規範規定EJB中禁止的操作有哪些?
1. 不能操作執行緒和執行緒API(執行緒API指非執行緒物件的方法如notify,wait等),2.不能操作awt,3.不能實現伺服器功能,4.不能對靜態屬 生存取,5.不能使用IO操作直接存取檔案系統,6.不能載入本地庫.,7.不能將this作為變數和返回,8.不能迴圈呼叫。

75remote介面和home介面主要作用
remote介面定義了業務方法,用於EJB客戶端呼叫業務方法。
home介面是EJB工廠用於建立和移除查詢EJB例項

76bean 例項的生命週期
對 於Stateless Session Bean、Entity Bean、Message Driven Bean一般存在緩衝池管理,而對於Entity Bean和Statefull Session Bean存在Cache管理,通常包含建立例項,設定上下文、建立EJB Object(create)、業務方法呼叫、remove等過程,對於存在緩衝池管理的Bean,在create之後例項並不從記憶體清除,而是採用緩衝 池排程機制不斷重用例項,而對於存在Cache管理的Bean則通過啟用和去啟用機制保持Bean的狀態並限制記憶體中例項數量。

77EJB的啟用機制
以Stateful Session Bean 為例:其Cache大小決定了記憶體中可以同時存在的Bean例項的數量,根據MRU或NRU演算法,例項在啟用和去啟用狀態之間遷移,啟用機制是當客戶端調 用某個EJB例項業務方法時,如果對應EJB Object發現自己沒有繫結對應的Bean例項則從其去啟用Bean儲存中(通過序列化機制儲存例項)回覆(啟用)此例項。狀態變遷前會呼叫對應的 ejbActive和ejbPassivate方法。

78EJB的幾種型別
會話(Session)Bean ,實體(Entity)Bean 訊息驅動的(Message Driven)Bean
會話Bean又可分為有狀態(Stateful)和無狀態(Stateless)兩種
實體Bean可分為Bean管理的持續性(BMP)和容器管理的持續性(CMP)兩種

79、客服端呼叫EJB物件的幾個基本步驟
設定JNDI服務工廠以及JNDI服務地址系統屬性,查詢Home介面,從Home介面呼叫Create方法建立Remote介面,通過Remote介面呼叫其業務方法。

80、如何給weblogic指定大小的記憶體?
在啟動Weblogic的指令碼中(位於所在Domian對應伺服器目錄下的startServerName),增加set MEM_ARGS=-Xms32m -Xmx200m,可以調整最小記憶體為32M,最大200M

81、如何設定的weblogic的熱啟動模式(開發模式)與產品釋出模式?
可以在管理控制檯中修改對應伺服器的啟動模式為開發或產品模式之一。或者修改服務的啟動檔案或者commenv檔案,增加set PRODUCTION_MODE=true。

82、如何啟動時不需輸入使用者名稱與密碼?
修改服務啟動檔案,增加 WLS_USER和WLS_PW項。也可以在boot.properties檔案中增加加密過的使用者名稱和密碼.

83、在weblogic管理制臺中對一個應用域(或者說是一個網站,Domain)進行jmsejb或連線池等相關資訊進行配置後,實際儲存在什麼檔案中?
儲存在此Domain的config.xml檔案中,它是伺服器的核心配置檔案。

84、說說weblogic中一個Domain的預設目錄結構?比如要將一個簡單的helloWorld.jsp放入何目錄下,然的在瀏覽器上就可打入http://://helloword.jsp就可以看到執行結果?又比如這其中用到了一個自己寫的javaBean該如何辦?
Domain 目錄伺服器目錄applications,將應用目錄放在此目錄下將可以作為應用訪問,如果是Web應用,應用目錄需要滿足Web應用目錄要求,jsp文 件可以直接放在應用目錄中,Javabean需要放在應用目錄的WEB-INF目錄的classes目錄中,設定伺服器的預設應用將可以實現在瀏覽器上無 需輸入應用名。

85、在weblogic中釋出ejb需涉及到哪些配置檔案
不同型別的EJB涉及的配置檔案不同,都涉及到的配置檔案包括ejb-jar.xml,weblogic-ejb-jar.xmlCMP實體Bean一般還需要weblogic-cmp-rdbms-jar.xml

86、如何在weblogic中進行ssl配置與客戶端的認證配置或說說j2ee(標準)進行ssl的配置
缺 省安裝中使用DemoIdentity.jks和DemoTrust.jks KeyStore實現SSL,需要配置伺服器使用Enable SSL,配置其埠,在產品模式下需要從CA獲取私有金鑰和數字證書,建立identity和trust keystore,裝載獲得的金鑰和數字證書。可以配置此SSL連線是單向還是雙向的。

87、如何檢視在weblogic中已經發布的EJB?
可以使用管理控制檯,在它的Deployment中可以檢視所有已釋出的EJB

88CORBA是什麼?用途是什麼?
CORBA 標準是公共物件請求代理結構(Common Object Request Broker Architecture),由物件管理組織 (Object Management Group,縮寫為 OMG)標準化。它的組成是介面定義語言(IDL), 語言繫結(binding:也譯為聯編)和允許應用程式間互操作的協議。 其目的為:用不同的程式設計語言書寫在不同的程序中執行,為不同的作業系統開發。

89、說說你所熟悉或聽說過的j2ee中的幾種常用模式?及對設計模式的一些看法
Session Facade Pattern:使用SessionBean訪問EntityBean
Message Facade Pattern:實現非同步呼叫
EJB Command Pattern:使用Command JavaBeans取代SessionBean,實現輕量級訪問
Data Transfer Object Factory:通過DTO Factory簡化EntityBean資料提供特性
Generic Attribute Access:通過AttibuteAccess介面簡化EntityBean資料提供特性
Business Interface:通過遠端(本地)介面和Bean類實現相同介面規範業務邏輯一致性
EJB架構的設計好壞將直接影響系統的效能、可擴充套件性、可維護性、元件可重用性及開發效率。專案越複雜,專案隊伍越龐大則越能體現良好設計的重要性。

90、說說在weblogic中開發訊息Bean時的persistentnon-persisten的差別
persistent方式的MDB可以保證訊息傳遞的可靠性,也就是如果EJB容器出現問題而JMS伺服器依然會將訊息在此MDB可用的時候傳送過來,而non-persistent方式的訊息將被丟棄。

既然沒有標準答案,就根據自己的所瞭解的,補充修正一下好了

91Servlet執行時一般實現哪幾個方法?
public void init(ServletConfig config)
public ServletConfig getServletConfig()
public String getServletInfo()
public void service(ServletRequest request,ServletResponse response)
public void destroy()

init ()方法在servlet的生命週期中僅執行一次,在伺服器裝載servlet時執行。預設的init()方法通常是符合要求的,不過也可以根據需要進行 override,比如管理伺服器端資源,一次性裝入GIF影象,初始化資料庫連線等,預設的inti()方法設定了servlet的初始化引數,並用它 的ServeltConfig物件引數來啟動配置,所以覆蓋init()方法時,應呼叫super.init()以確保仍然執行這些任務。

service ()方法是servlet的核心,在呼叫service()方法之前,應確保已完成init()方法。對於HttpServlet,每當客戶請求一個 HttpServlet物件,該物件的service()方法就要被呼叫,HttpServlet預設的service()方法的服務功能就是呼叫與 HTTP請求的方法相應的do功能,doPost()和doGet(),所以對於HttpServlet,一般都是重寫doPost()和doGet() 方法。

destroy()方法在servlet的生命週期中也僅執行一次,即在伺服器停止解除安裝servlet時執行,把servlet作為 伺服器程序的一部分關閉。預設的destroy()方法通常是符合要求的,但也可以override,比如在解除安裝servlet時將統計數字儲存在檔案 中,或是關閉資料庫連線。

getServletConfig()方法返回一個servletConfig物件,該物件用來返回初始化引數和servletContext。servletContext介面提供有關servlet的環境資訊。

getServletInfo()方法提供有關servlet的資訊,如作者,版本,版權。

92j2ee常用的設計模式?說明工廠模式。
Java中的23種設計模式:
Factory(工廠模式), Builder(建造模式), Factory Method(工廠方法模式),
Prototype(原始模型模式),Singleton(單例模式), Facade(門面模式),
Adapter(介面卡模式), Bridge(橋樑模式), Composite(合成模式),
Decorator(裝飾模式), Flyweight(享元模式), Proxy(代理模式),
Command(命令模式), Interpreter(直譯器模式), Visitor(訪問者模式),
Iterator(迭代子模式), Mediator(調停者模式), Memento(備忘錄模式),
Observer(觀察者模式), State(狀態模式), Strategy(策略模式),
Template Method(模板方法模式), Chain Of Responsibleity(責任鏈模式)
工 廠模式:工廠模式是一種經常被使用到的模式,根據工廠模式實現的類可以根據提供的資料生成一組類中某一個類的例項,通常這一組類有一個公共的抽象父類並且 實現了相同的方法,但是這些方法針對不同的資料進行了不同的操作。首先需要定義一個基類,該類的子類通過不同的方法實現了基類中的方法。然後需要定義一個 工廠類,工廠類可以根據條件生成不同的子類例項。當得到子類的例項後,開發人員可以呼叫基類中的方法而不必考慮到底返回的是哪一個子類的例項。

93EJB需直接實現它的業務介面或Home介面嗎,請簡述理由。
遠端介面和Home介面不需要直接實現,他們的實現程式碼是由伺服器產生的,程式執行中對應實現類會作為對應介面型別的例項被使用。

其實一直都不是很明白EJB的remote介面,home介面,Bean類究竟是如何使用的,或許應該進一步瞭解EJB的原理吧,查到了一個原創文章,那就說說EJB呼叫的原理吧。其實在這個問題上,最需要理解的是RMI機制原理。

一個遠端物件至少要包括4個class檔案:遠端物件、遠端物件介面、實現遠端介面的物件的stub、物件的skeleton。

而在EJB中則至少要包括10個class:
Bean類,特定App Server的Bean實現類
Bean的remote介面,特定App Server的remote介面實現類,特定App Server的remote介面的實現類的stub類和skeleton類。
Bean的home介面,特定App Server的home介面實現類,特定App Server的home介面的實現類的stub類和skeleton類。

和RMI不同的是,EJB中這10個class真正需要使用者寫的只有3個,Bean類,remote介面,home介面,其它的7個究竟怎麼生成,被打包在哪裡,是否需要更多的類檔案,否根據不同的App Server表現出較大的差異。

Weblogic:
home介面和remote介面的weblogic的實現類的stub類和skeleton類是在EJB被部署到weblogic的時候,由weblogic動態生成stub類和skeleton類的位元組碼,所以看不到這4個類檔案。

對 於一次客戶端遠端呼叫EJB,要經過兩個遠端物件的多次RMI迴圈。首先是通過JNDI查詢Home介面,獲得Home介面的實現類,這個過程其實相當復 雜,首先是找到Home介面的Weblogic實現類,然後建立一個Home介面的Weblogic實現類的stub類的物件例項,將它序列化傳送給客戶 端(注意stub類的例項是在第1次RMI迴圈中,由伺服器動態傳送給客戶端的,因此不需要客戶端儲存Home介面的Weblogic實現類的stub 類),最後客戶端獲得該stub類的物件例項(普通的RMI需要在客戶端儲存stub類,而EJB不需要,因為伺服器會把stub類的物件例項傳送給客戶 端)。

客戶端拿到伺服器給它的Home介面的Weblogic實現類的stub類物件例項以後,呼叫stub類的create方法, (在程式碼上就是home.create(),但是後臺要做很多事情),於是經過第2次RMI迴圈,在伺服器端,Home介面的Weblogic實現類的 skeleton類收到stub類的呼叫資訊後,由它再去呼叫Home介面的Weblogic實現類的create方法。

在服務端,Home 介面的Weblogic實現類的create方法再去呼叫Bean類的Weblogic實現類的ejbCreate方法,在服務端建立或者分配一個EJB 例項,然後將這個EJB例項的遠端介面的Weblogic實現類的stub類物件例項序列化傳送給客戶端。

客戶端收到remote接 口的Weblogic實現類的stub類的物件例項,對該物件例項的方法呼叫(在客戶端程式碼中實際上就是對remote介面的呼叫),將傳送給伺服器端 remote介面的Weblogic實現類的skeleton類物件,而skeleton類物件再呼叫相應的remote介面的Weblogic實現類, 然後remote介面的Weblogic實現類再去呼叫Bean類的Weblogic實現類,如此就完成一次EJB物件的遠端呼叫。

先拿普通RMI來說,有4個class,分別是遠端物件,物件的介面,物件的stub類和skeleton類。而物件本身和物件的stub類同時都實現了介面類。而我們在客戶端程式碼呼叫遠端物件的時候,雖然在程式碼中操縱介面,實質上是在操縱stub類,例如:
介面類:Hello
遠端物件:Hello_Server
stub類:Hello_Stub
skeleton類:Hello_Skeleton

客戶端程式碼要這樣寫:
Hello h = new Hello_Stub();
h.getString();

我們不會這些寫:
Hello_Stub h = new Hello_Stub();
h.getString();

因 為使用介面適用性更廣,就算更換了介面實現類,也不需要更改程式碼。因此客戶端需要Hello.class和Hello_Stub.class這兩個檔案。 但是對於EJB來說,就不需要Hello_Stub.class,因為伺服器會發送給它,但是Hello.class檔案客戶端是省不了的,必須有。表面 上我們的客戶端程式碼在操縱Hello,但別忘記了Hello只是一個介面,抽象的,實質上是在操縱Hello_Stub。

拿Weblogic上的EJB舉例子,10個class分別是:
Bean類:HelloBean (使用者編寫)
Bean類的Weblogic實現類:HelloBean_Impl (EJBC生成)

Home介面:HelloHome (使用者編寫)
Home介面的Weblogic實現類 HelloBean_HomeImpl(EJBC生成)
Home介面的Weblogic實現類的stub類 HelloBean_HomeImpl_WLStub(部署的時候動態生成位元組碼)
Home介面的Weblogic實現類的skeleton類 HelloBean_HomeImpl_WLSkeleton(部署的時候動態生成位元組碼)

Remote介面: Hello (使用者編寫)
Remote介面的Weblogic實現類 HelloBean_EOImpl(EJBC生成)
Remote介面的Weblogic實現類的stub類 HelloBean_EOImpl_WLStub(部署的時候動態生成位元組碼)
Remote介面的Weblogic實現類的skeleton類 HelloBean_EOImpl_WLSkeleton(部署的時候動態生成位元組碼)

客戶端只需要Hello.class和HelloHome.class這兩個檔案。

HelloHome home = (Home) PortableRemoteObject.narrow(ctx.lookup("Hello"), HelloHome.class);

這一行程式碼是從JNDI獲得Home介面,但是請記住!介面是抽象的,那麼home這個物件到底是什麼類的物件例項呢?很簡單,用toString()輸出看一下就明白了,下面一行是輸出結果:
[email protected]
這表明home這個通過從伺服器的JNDI樹上查詢獲得的物件實際上是HelloBean_HomeImpl_WLStub類的一個例項。
接下來客戶端程式碼:

Hello h = home.create()

同樣Hello只是一個抽象的介面,那麼h物件是什麼東西呢?列印一下:
[email protected]
原來是HelloBean_EOImpl_WLStub的一個物件例項。

用這個例子來簡述一遍EJB呼叫過程:

首先客戶端JNDI查詢,服務端JNDI樹上Hello這個名字實際上繫結的物件是HelloBean_HomeImpl_WLStub,所以服務端將建立HelloBean_HomeImpl_WLStub的一個物件例項,序列化返回給客戶端。

於 是客戶端得到home物件,表面上是得到HelloHome介面的例項,實際上是進行了一次遠端呼叫得到了 HelloBean_HomeImpl_WLStub類的物件例項,別忘記了HelloBean_HomeImpl_WLStub也實現了 HelloHome介面。

然後home.create()實質上就是 HelloBean_HomeImpl_WLStub.create(),該方法將傳送資訊給 HelloBean_HomeImpl_WLSkeleton,而HelloBean_HomeImpl_WLSkeleton接受到資訊後,再去呼叫 HelloBean_HomeImpl的create方法,至此完成第1次完整的RMI迴圈。

注意在這次RMI迴圈過程中,遠端物件 是HelloBean_HomeImpl,遠端物件的介面是HelloHome,物件的stub是HelloBean_HomeImpl_WLStub, 物件的skeleton是HelloBean_HomeImpl_WLSkeleton。

然後HelloBean_HomeImpl 再去呼叫HelloBean_Impl的ejbCreate方法,而HelloBean_Impl的ejbCreate方法將負責建立或者分配一個 Bean例項,並且建立一個HelloBean_EOImpl_WLStub的物件例項。

這一步比較有趣的是,在前一步RMI迴圈 中,遠端物件HelloBean_HomeImpl在客戶端有一個代理類HelloBean_HomeImpl_WLStub,但在這一步, HelloBean_HomeImpl自己卻充當了HelloBean_Impl的代理類,只不過HelloBean_HomeImpl不在客戶端,而是 在服務端,因此不進行RMI。

然後HelloBean_EOImpl_WLStub的物件例項序列化返回給客戶端,這一步也很有趣, 上次RMI過程,主角是HelloBean_HomeImpl和它的代理類HelloBean_HomeImpl_WLStub,但這這一次換成了 HelloBean_EOImpl和它的代理類HelloBean_EOImpl_WLStub來玩了。


Hello h = home.create();h.helloWorld();

假設Hello介面有一個helloWorld遠端方法,那麼表面上是在呼叫Hello介面的helloWorld方法,實際上是在呼叫HelloBean_EOImpl_WLStub的helloWorld方法。

然 後HelloBean_EOImpl_WLStub的helloWorld方法將傳送資訊給伺服器上的 HelloBean_EOImpl_WLSkeleton,而HelloBean_EOImpl_WLSkeleton收到資訊以後,再去呼叫 HelloBean_EOImpl的helloWorld方法。至此,完成第2次完整的RMI迴圈過程。

在剛才 HelloBean_EOImpl是作為遠端物件被呼叫的,它的代理類是HelloBean_EOImpl_WLStub,但現在 HelloBean_EOImpl要作為HelloBean_Impl的代理類了。現在HelloBean_EOImpl去呼叫 HelloBean_Impl的helloWorld方法。注意!HelloBean_Impl繼承了HelloBean,而HelloBean中的 helloWorld方法是我們親自編寫的程式碼,現在終於呼叫到了我們編寫的程式碼了!

至此,一次EJB呼叫過程終於完成。在整個過程 中,服務端主要要呼叫的類是HelloBean_Impl, HelloBean_HomeImpl,HelloBean_HomeImpl_WLSkeleton,HelloBean_EOImpl, HelloBean_EOImpl_WLSkeleton。客戶端主要呼叫的類是HelloBean_HomeImpl_WLStub, HelloBean_EOImpl_WLStub,這兩個類在客戶端程式碼中並不會直接出現,出現在程式碼中的類是他們的介面HelloHome和 Hello,因此客戶端需要這兩個介面檔案,而Stub是伺服器傳送給他們的。

94、排序都有哪幾種方法?請列舉。用JAVA實現一個快速排序。
排序的方法有:插入排序(直接插入排序、希爾排序),交換排序(氣泡排序、快速排序),選擇排序(直接選擇排序、堆排序),歸併排序,分配排序(箱排序、基數排序)
快速排序的虛擬碼。
/ /使用快速排序方法對a[ 0 :n- 1 ]排序
從a[ 0 :n- 1 ]中選擇一個元素作為m i d d l e,該元素為支點
把餘下的元素分割為兩段left 和r i g h t,使得l e f t中的元素都小於等於支點,而right 中的元素都大於等於支點
遞迴地使用快速排序方法對left 進行排序
遞迴地使用快速排序方法對right 進行排序
所得結果為l e f t + m i d d l e + r i g h t

95、請對以下在J2EE中常用的名詞進行解釋(或簡單描述)
web 容器:給處於其中的應用程式元件(JSP,SERVLET)提供一個環境,使JSP,SERVLET直接和容器中的環境變數接介面互,不必關注其它系統問 題。主要有WEB伺服器來實現。例如:TOMCAT,WEBLOGIC,WEBSPHERE等。該容器提供的介面嚴格遵守J2EE規範中的WEB APPLICATION 標準。我們把遵守以上標準的WEB伺服器就叫做J2EE中的WEB容器。
Web container:實現J2EE體系結構中Web元件協議的容器。這個協議規定了一個Web元件執行時的環境,包括安全,一致性,生命週期管理,事務, 配置和其它的服務。一個提供和JSP和J2EE平臺APIs介面相同服務的容器。一個Web container 由Web伺服器或者J2EE伺服器提供。
EJB容器:Enterprise java bean 容器。更具有行業領域特色。他提供給執行在其中的元件EJB各種管理功能。只要滿足J2EE規範的EJB放入該容器,馬上就會被容器進行高效率的管理。並 且可以通過現成的介面來獲得系統級別的服務。例如郵件服務、事務管理。
一個實現了J2EE體系結構中EJB元件規範的容器。
這個規範指定了一個Enterprise bean的執行時環境,包括安全,一致性,生命週期,事務,
配置,和其他的服務。
JNDI:(Java Naming & Directory Interface)JAVA命名目錄服務。主要提供的功能是:提供一個目錄系統,讓其它各地的應用程式在其上面留下自己的索引,從而滿足快速查詢和定位分散式應用程式的功能。
JMS:(Java Message Service)JAVA訊息服務。主要實現各個應用程式之間的通訊。包括點對點和廣播。
JTA:(Java Transaction API)JAVA事務服務。提供各種分散式事務服務。應用程式只需呼叫其提供的介面即可。
JAF:(Java Action FrameWork)JAVA安全認證框架。提供一些安全控制方面的框架。讓開發者通過各種部署和自定義實現自己的個性安全控制策略。
RMI/IIOP: (Remote Method Invocation /internet物件請求中介協議)他們主要用於通

相關推薦

免費視頻教程:java經典試題深度解析

免費視頻教程:java經典面試題深度解析 對於很多初學者來說,學好java在後期面試的階段都沒什麽經驗,為了讓大家更好的了解面試相關知識,今天在這裏給大家分享了一個java經典面試題深度解析的免費視頻教程,需要的朋友可以看看,作為參考! 課程簡介:精選多年來名企在各地的Jav

java經典試題深度解析免費視頻教程分享

java經典面試題深度解析免費視頻教程分享 對於很多初學者來說,學好java在後期面試的階段都沒什麽經驗,為了讓大家更好的了解面試相關知識,今天在這裏給大家分享了一個java經典面試題深度解析的免費視頻教程,需要的朋友可以看看,作為參考! 課程簡介:精選多年來名企在各地的Java

java經典試題---2----->Spring框架的相關介紹

原來 配置 主動 效果好 xml配置 優點 持久層 關系 文件 Spring是一個開源輕量級的框架,它的核心是控制反轉(IOC)和面向切面編程(AOP)。 作為業務層框架的spring能夠很好地整合表現層跟持久層。 IOC:將類的創建和依賴關系寫到配置文件裏,可以讓一個

java經典試題總結(一)

Java經典面試題總結繼續更新,有需要的小夥伴可以路過不要錯過了!看上一篇面試題總結的反響還是很不錯的,就繼續更新了,也非常感謝各位小夥伴的持續關注…… 這次更偏基礎一些! 1、String 和StringBuffer 的區別? 答:JAVA 平臺提供了兩個類:String 和StringBuffer,

java經典試題總結(二)

上一次更新的java面試題,很多小夥伴反應很簡單,其實上一期更新的就是更偏基礎的面試題,但這並不意味著,面試就這麼簡單,在java的學習中,有從Java基礎、框架、設計模式等等都是重點學習的點。在本文的面試題分享中,我們循序漸進,儘量挑一些重點的內容來分享! 1、當一個物件被當作引數傳遞到一個方法後,此方法

Java經典試題總結(三)

本期的java面試題是偏向資料庫方面的,對相關技術知識匱乏的,或者對這方面不大自信的同學,面試之前可以參考一下這套題,這只是節選,試運營一下,如果不能滿足你們的需求,可以直接評論留言! 1、檢視的優缺點答:優點: 1)對資料庫的訪問,因為檢視可以有選擇性的選取資料庫裡的一部分。 2 )使用者通過簡單的查詢可

java經典試題:單鏈表反轉問題詳解(含遞迴法)

java經典面試題:單鏈表反轉問題,有兩種方法,一種為迴圈遍歷法,一種遞迴法。 1、迴圈遍歷法   首先設定三個節點,把當前節點的下一節點指向它前面的節點,此時你會發現指標鏈會斷,所以要先把它後面一個節點用nextNode儲存下來,之後把節點向後移動遍歷即可。    程式碼如下: //

MongoDB與Java 經典試題、課程,好資源值得收藏

如何學習好Java、Spring Boot、如果學習好MongoDB?如何拿高薪?阿里巴巴雲棲社群整理了MongoDB與Java 經典面試題、課程,好資源值得收藏,陸續更新中。 【MongoDB面試題】[@徐雷frank]MongoDB如果有效應對單節點故障? https://yq.aliyun.com

Java經典試題總結(六)

本次的面試題:多執行緒知識的面試解答題。 1. 有T1、T2、T3三個執行緒,如何怎樣保證T2在T1執行完後執行,T3在T2執行完後執行? 答:使用join方法。 join方法的功能是使非同步執行的執行緒變成同步執行。即呼叫執行緒例項的start方法後,該方法會立即返回,如果呼叫start方法後

100道Java經典試題及答案解析

作用域public,private,protected,以及不寫時的區別 答:區別如下: 作用域 當前類 同一package 子孫類 其他package public √ √ √ √ protected √ √ √ × friendly √ √ ×

java經典試題(1)

1、 面向物件的特徵有哪些方面 1.抽象: 抽象就是忽略一個主題中與當前目標無關的那些方面,以便更充分地注意與當前目標有關的方面。抽象並不打算了解全部問題,而只是選擇其中的一部分,暫時不用部分細節。

Java經典試題(N人迴圈報M個數出列)實現

面試題:  設有N個人依次圍成一圈,從第1個人開始報數,第M個人出列,然後從出列的下一個人開始報數,數到第M個人又出列,...,如此反覆到所有的人全部出列為止,設N個人的編號分別為1,2,...,N,打印出出列的順序,要求用java實現。 參考程式碼: package

java經典試題

Java基礎方面:0、作用域public,private,protected,以及不寫時的區別答:區別如下:作用域 當前類 同一package 子孫類 其他packagepublic √ √ √ √protected √ √ √ ×friendly √ √ × ×private √ × × ×不寫時預設為f

序列化介面的id有什麼用?—— Java經典試題系列

我: 物件經常要通過IO進行傳送,讓你寫程式傳遞物件,你會怎麼做?把物件的狀態資料用某種格式寫入到硬碟,Person->“zxx,male,28,30000”àPerson,既然大家都要這麼幹,並且沒有個統一的幹法,於是,sun公司就提出一種統一的解決方案,它會把物件變成某個格式進行輸入和輸出,這種格式

JAVA經典試題(二)--如何體現JavaScript的繼承關係?

js裡常用的如下兩種繼承方式: 原型鏈繼承(物件間的繼承) 類式繼承(建構函式間的繼承) 由於js不像java那樣是真正面向物件的語言,js是基於物件的,它沒有類的概念。所以,要想實現繼承,可以用js的原型prototype機制或者用apply和call方

JAVA經典試題(一)-- 判斷以及防止SQL注入

SQL注入是目前黑客最常用的攻擊手段,它的原理是利用資料庫對特殊識別符號的解析強行從頁面向後臺傳入。改變SQL語句結構,達到擴充套件許可權、建立高等級使用者、強行修改使用者資料等等操作。 那怎麼判斷是否被SQL注入了呢? 通過SQL注入的原理我們知道,判斷S

2019年19道java經典試題(附答案)

可變對象 caption 反射 進制 不可 tostring 靈活性 clear 散列表 1.不可變對象 指對象一旦被創建狀態不能再改變。任何修改都會創建一個新的對象,如 String、Integer及其它包裝類。 2.能否創建一個包含可變對象的不可變

Java 經典試題:聊一聊 JUC 下的 CopyOnWriteArrayList

ArrayList 是我們常用的工具類之一,但是在多執行緒的情況下,ArrayList 作為共享變數時,並不是執行緒安全的。主要有以下兩個原因: - 1、 ArrayList 自身的 elementData、size、modCount 在進行操作的時候,都沒有加鎖; - 2、這些變數沒有被 volatil

Java 經典試題:聊一聊 JUC 下的 LinkedBlockingQueue

本文聊一下 JUC 下的 LinkedBlockingQueue 佇列,先說說 LinkedBlockingQueue 佇列的特點,然後再從原始碼的角度聊一聊 LinkedBlockingQueue 的主要實現~ LinkedBlockingQueue 有以下特點: - **LinkedBlockingQu

經典Java基礎試題集錦

改變 java基礎 local 一個 是否 賦值 文件 所有 date 問題:如果main方法被聲明為private會怎樣? 答案:能正常編譯,但運行的時候會提示”main方法不是public的”。 問題:Java裏的傳引用和傳值的區別是什麽? 答案:傳引用是指傳遞的是