網站首頁 工作範例 辦公範例 個人範例 黨團範例 簡歷範例 學生範例 其他範例 專題範例

關於JAVA的筆試題有哪些

欄目: 筆試題目 / 釋出於: / 人氣:1.14W

Java語言作為靜態面向物件程式語言的代表,極好地實現了面向物件理論,允許程式設計師以優雅的思維方式進行復雜的程式設計。下面是本站小編為你整理的JAVA筆試題150例,希望對你有所幫助!

關於JAVA的筆試題有哪些

JAVA筆試題150例

一、Java基礎方面

1、作用域public,private,protected,以及不寫時的區別

答:區別如下:

作用域 當前類 同一package 子孫類 其他package

public √ √ √ √

protected √ √ √ ×

friendly √ √ × ×

private √ × × ×

不寫時預設為friendly

2、Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(介面)

答:匿名的內部類是沒有名字的內部類。可以繼承抽象(SDK1.5沒有限制),但一個內部類可以作為一個介面,由另一個內部類實現

3、Static Nested Class 和 Inner Class的不同

答:Nested Class (一般是C++的說法),Inner Class (一般是JAVA的說法)。Java內部類與C++巢狀類最大的不同就在於是否有指向外部的引用上。注: 靜態內部類(Inner Class)意味著1建立一個static內部類的物件,不需要一個外部類物件,2不能從一個static內部類的一個物件訪問一個外部類物件

4、&和&&的區別

答:&是位運算子,表示按位與運算,&&是邏輯運算子,表示邏輯與(and)

5、Collection 和 Collections的區別

答:Collection是集合類的上級介面,繼承與他的介面主要有Set 和List.

Collections是針對集合類的一個幫助類,他提供一系列靜態方法實現對各種集合的搜尋、排序、執行緒安全化等操作

6、什麼時候用assert

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

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

答:"xyz"本身作為字元常量,在組合語言中應該作為常量放在資料段,Java有一個類似資料段的constant pool儲存這個常量,在classloader載入這個類的時候就把"xyz"和這個類的其他一些資訊放在constant pool new String("xyz")根據常量"xyz"在heap上建立String物件所以,一共兩個物件

String(String original) Initializes a newly created String object so that it represents the same sequence of characters as the argument; in other words, the newly created string is a copy of the argument string.

8、d(11.5)等於多少? d(-11.5)等於多少

答: d(11.5)==12;d(-11.5)==-11;round方法返回與引數最接近的長整數,引數加1/2後求其floor

9、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;(可以正確編譯)

10、Java有沒有goto

答:java中的保留字,現在沒有在java中使用

11、陣列有沒有length這個方法? String有沒有length這個方法

答:陣列沒有length這個方法,有length的屬性。String有length這個方法

12、Overload和Override的區別。Overloaded的方法是否可以改變返回值的型別

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

13、Set裡的元素是不能重複的,那麼用什麼方法來區分重複與否呢? 是用==還是equals? 它們有何區別

答:Set裡的元素是不能重複的,那麼用iterator方法來區分重複與否。equals是判斷兩個Set是否相等, equals和==方法決定引用值是否指向同一物件equals在類中被覆蓋,為的是當兩個分離的物件的內容和型別相配的話,返回真值

14、給我一個你最常見到的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

15、error和exception有什麼區別

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

16、List, Set, Map是否繼承自Collection介面

答:List,Set是,Map不是

17、abstract class和interface有什麼區別

答:宣告方法的存在而不去實現它的類被叫做抽象類(abstract class),它用於要建立一個體現某些基本行為的類,併為該類宣告方法,但不能在該類中實現該類的情況。不能建立abstract 類的例項。然而可以建立一個變數,其型別是一個抽象類,並讓它指向具體子類的一個例項。不能有抽象建構函式或抽象靜態方法。Abstract 類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法

介面(interface)是抽象類的變體。在介面中,所有方法都是抽象的。多繼承性可通過實現這樣的介面而獲得。介面中的所有方法都是抽象的,沒有一個有程式體。介面只可以定義static final成員變數。介面的實現與子類相似,除了該實現類不能從介面定義中繼承行為。當類實現特殊介面時,它定義(即將程式體給予)所有這種介面的方法。然後,它可以在實現了該介面的類的任何物件上呼叫介面的方法。由於有抽象類,它允許使用介面名作為引用變數的型別。通常的動態聯編將生效。引用可以轉換到介面型別或從介面型別轉換,instanceof 運算子可以用來決定某物件的類是否實現了介面

18、abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized

答:都不能

19、介面是否可繼承介面? 抽象類是否可實現(implements)介面? 抽象類是否可繼承實體類(concrete class)

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

20、構造器Constructor是否可被override

答:構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被過載Overloading

21、是否可以繼承String類

答:String類是final類故不可以繼承

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

答:會執行,在return前執行

23、用最有效率的方法算出2乘以8等於幾

答:2 << 3

24、兩個物件值相同(ls(y) == true),但卻可有不同的hash code,這句話對不對

答:不對,有相同的hash code

25、當一個物件被當作引數傳遞到一個方法後,此方法可改變這個物件的屬性,並可返回變化後的結果,那麼這裡到底是值傳遞還是引用傳遞

答:是值傳遞。Java 程式語言只有值傳遞引數。當一個物件例項作為一個引數被傳遞到方法中時,引數的值就是對該物件的引用。物件的內容可以在被呼叫的方法中改變,但物件的引用是永遠不會改變的

26、swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上

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

27、ArrayList和Vector的區別,HashMap和Hashtable的區別

答:就ArrayList與Vector主要從二方面來說:

1、同步性:Vector是執行緒安全的,也就是說是同步的,而ArrayList是執行緒序不安全的,不是同步的

2、資料增長:當需要增長時,Vector預設增長為原來一倍,而ArrayList卻是原來的一半

就HashMap與HashTable主要從三方面來說:

1、歷史原因:Hashtable是基於陳舊的Dictionary類的,HashMap是Java 1.2引進的Map介面的一個實現

2、同步性:Hashtable是執行緒安全的,也就是說是同步的,而HashMap是執行緒序不安全的,不是同步的

3、值:只有HashMap可以讓你將空值作為一個表的條目的key或value 28、char型變數中能不能存貯一箇中文漢字?為什麼?

答:是能夠定義成為一箇中文的,因為java中以unicode編碼,一個char佔16個位元組,所以放一箇中文是沒問題的

如果用gbk的本地編碼的話可以.如果用utf-8的話,可能不行。

29、GC是什麼? 為什麼要有GC

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

30、float型float f=3.4是否正確?

答:不正確。精度不準確,應該用強制型別轉換,如下所示:float f=(float)3.4; float f = 3.4f;

31、介紹JAVA中的Collection FrameWork(包括如何寫自己的資料結構)?

答:Collection FrameWork如下:

Collection

├List

│├LinkedList

│├ArrayList

│└Vector

│ └Stack

└Set

Map

├Hashtable

├HashMap

└WeakHashMap

Collection是最基本的集合介面,一個Collection代表一組Object,即Collection的元素(Elements)

Map提供key到value的對映

32、抽象類與介面?

答:抽象類與介面都用於抽象,但是抽象類(JAVA中)可以有自己的部分實現,而介面則完全是一個標識(同時有多實現的功能)。

JAVA類實現序例化的方法是實現alizable介面

Collection框架中實現比較要實現Comparable 介面和 Comparator 介面

33、STRING與STRINGBUFFER的區別。

答:STRING的長度是不可變的,STRINGBUFFER的長度是可變的。如果你對字串中的內容經常進行操作,特別是內容要修改時,那麼使用StringBuffer,如果最後需要String,那麼使用StringBuffer的toString方法

34、談談final, finally, finalize的區別

答:final—修飾符(關鍵字)如果一個類被宣告為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被宣告為 abstract的,又被宣告為final的。將變數或方法宣告為final,可以保證它們在使用中不被改變。被宣告為final的變數必須在宣告時給定初值,而在以後的引用中只能讀取,不可修改。被宣告為final的方法也同樣只能使用,不能過載

finally—再異常處理時提供 finally 塊來執行任何清除操作。如果丟擲一個異常,那麼相匹配的 catch 子句就會執行,然後控制就會進入 finally 塊(如果有的話)

finalize—方法名。Java 技術允許使用 finalize 方法在垃圾收集器將物件從記憶體中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在確定這個物件沒有被引用時對這個物件呼叫的。它是在 Object 類中定義的,因此所有的類都繼承了它。子類覆蓋 finalize 方法以整理系統資源或者執行其他清理工作。finalize 方法是在垃圾收集器刪除物件之前對這個物件呼叫的

35、面向物件的特徵有哪些方面

答:主要有以下四方面:

1.抽象:抽象就是忽略一個主題中與當前目標無關的那些方面,以便更充分地注意與當前目標有關的方面。抽象並不打算了解全部問題,而只是選擇其中的一部分,暫時不用部分細節。抽象包括兩個方面,一是過程抽象,二是資料抽象。

2.繼承:繼承是一種聯結類的層次模型,並且允許和鼓勵類的重用,它提供了一種明確表述共性的方法。物件的一個新類可以從現有的類中派生,這個過程稱為類繼承。新類繼承了原始類的特性,新類稱為原始類的派生類(子類),而原始類稱為新類的基類(父類)。派生類可以從它的基類那裡繼承方法和例項變數,並且類可以修改或增加新的方法使之更適合特殊的需要。

3.封裝:封裝是把過程和資料包圍起來,對資料的訪問只能通過已定義的介面。面向物件計算始於這個基本概念,即現實世界可以被描繪成一系列完全自治、封裝的物件,這些物件通過一個受保護的介面訪問其他物件。

4. 多型性:多型性是指允許不同類的物件對同一訊息作出響應。多型性包括引數化多型性和包含多型性。多型性語言具有靈活、抽象、行為共享、程式碼共享的優勢,很好的解決了應用程式函式同名問題。

36、String是最基本的資料型別嗎

答:不是,基本資料型別包括byte、int、char、long、float、double、boolean和short。

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

37、int 和 Integer 有什麼區別

答:Java 提供兩種不同的型別:引用型別和原始型別(或內建型別)。

Int是java的原始資料型別,Integer是java為int提供的wapper。Java為每個原始型別提供了封裝類。

原始型別封裝類:

boolean : Boolean

char : Character

byte : Byte

short : Short

int : Integer

long : Long

float : Float

double : Double

引用型別和原始型別的行為完全不同,並且它們具有不同的語義。引用型別和原始型別具有不同的特徵和用法,它們包括:大小和速度問題,這種型別以哪種型別的資料結構儲存,當引用型別和原始型別用作某個類的例項資料時所指定的預設值。物件引用例項變數的預設值為 null,而原始型別例項變數的預設值與它們的型別有關

38、執行時異常與一般異常有何異同

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

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

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

40、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演算法都大概一樣,所以效能不會有很大的差異。

41、heap和stack有什麼區別

答:棧是一種線形集合,其新增和刪除元素的操作應在同一段完成。棧按照後進先出的方式進行處理。堆是棧的一個組成元素

42、Java的介面和C++的虛類的相同和不同處

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

43、Java中的異常處理機制的簡單原理和應用

答:當JAVA程式違反了JAVA的語義規則時,JAVA虛擬機器就會將發生的錯誤表示為一個異常。違反語義規則包括2種情況。一種是JAVA類庫內建的語義檢查。例如陣列下標越界,會引發IndexOutOfBoundsException;訪問null的物件時會引發NullPointerException。另一種情況就是JAVA允許程式設計師擴充套件這種語義檢查,程式設計師可以建立自己的異常,並自由選擇在何時用throw關鍵字引發異常。所有的異常都是able的子類。

43、垃圾回收的優點和原理。並考慮2種回收機制

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

44、你所知道的集合類都有哪些?主要方法?

答:最常用的集合類是 List 和 Map。 List 的具體實現包括 ArrayList 和 Vector,它們是可變大小的列表,比較適合構建、儲存和操作任何型別物件的元素列表。 List 適用於按數值索引訪問元素的情形。

Map 提供了一個更通用的元素儲存方法。 Map 集合類用於儲存元素對(稱作"鍵"和"值"),其中每個鍵對映到一個值。

45、描述一下JVM載入class檔案的原理機制?

答:JVM中類的裝載是由ClassLoader和它的子類來實現的,Java ClassLoader 是一個重要的Java執行時系統元件。它負責在執行時查詢和裝入類檔案的類。

46、排序都有哪幾種方法?請列舉 答:排序的方法有:插入排序(直接插入排序、希爾排序),交換排序(氣泡排序、快速排序),選擇排序(直接選擇排序、堆排序),歸併排序,分配排序(箱排序、基數排序)

快速排序的虛擬碼。

使用快速排序方法對a[0 : n-1]排序:

從a[0 : n-1]中選擇一個元素作為middle,該元素為支點,把餘下的元素分割為兩段left和right,使得left中的元素都小於等於支點,而right中的元素都大於等於支點。

遞迴地使用快速排序方法對left進行排序

遞迴地使用快速排序方法對right 進行排序

所得結果為left + middle + right

47、JAVA語言如何進行異常處理,關鍵字:throws,throw,try,catch,finally分別代表什麼意義?在try塊中可以丟擲異常嗎?

答:Java通過面向物件的方法進行異常處理,把各種不同的異常進行分類,並提供了良好的介面。在Java中,每個異常都是一個物件,它是Throwable類或其它子類的例項。當一個方法出現異常後便丟擲一個異常物件,該物件中包含有異常資訊,呼叫這個物件的方法可以捕獲到這個異常並進行處理。Java的異常處理是通過5個關鍵詞來實現的:try、catch、throw、throws和finally。一般情況下是用try來執行一段程式,如果出現異常,系統會丟擲(throws)一個異常,這時候你可以通過它的型別來捕捉(catch)它,或最後(finally)由預設處理器來處理。

用try來指定一塊預防所有"異常"的程式。緊跟在try程式後面,應包含一個catch子句來指定你想要捕捉的"異常"的型別。

throw語句用來明確地丟擲一個"異常"。

throws用來標明一個成員函式可能丟擲的各種"異常"。

Finally為確保一段程式碼不管發生什麼"異常"都被執行一段程式碼。

可以在一個成員函式呼叫的外面寫一個try語句,在這個成員函式內部寫另一個try語句保護其他程式碼。每當遇到一個try語句,"異常"的框架就放到堆疊上面,直到所有的try語句都完成。如果下一級的try語句沒有對某種"異常"進行處理,堆疊就會展開,直到遇到有處理這種"異常"的try語句。

48、一個""原始檔中是否可以包括多個類(不是內部類)?有什麼限制?

答:可以。必須只有一個類名與檔名相同。

49、java中有幾種型別的流?JDK為每種型別的流提供了一些抽象類以供繼承,請說出他們分別是哪些類?

答:位元組流,字元流。位元組流繼承於InputStream OutputStream,字元流繼承於InputStreamReader OutputStreamWriter。在包中還有許多其他的流,主要是為了提高效能和使用方便。

50、java中會存在記憶體洩漏嗎,請簡單描述。

答:會。自己實現堆載的資料結構時有可能會出現記憶體洩露,可參看effective java.

51、java中實現多型的機制是什麼?

答:方法的重寫Overriding和過載Overloading是Java多型性的不同表現。重寫Overriding是父類與子類之間多型性的一種表現,過載Overloading是一個類中多型性的一種表現。

52、垃圾回收器的基本原理是什麼?垃圾回收器可以馬上回收記憶體嗎?有什麼辦法主動通知虛擬機器進行垃圾回收

答:對於GC來說,當程式設計師建立物件時,GC就開始監控這個物件的地址、大小以及使用情況。通常,GC採用有向圖的方式記錄和管理堆(heap)中的所有物件。通過這種方式確定哪些物件是"可達的",哪些物件是"不可達的"。當GC確定一些物件為"不可達"時,GC就有責任回收這些記憶體空間。可以。程式設計師可以手動執行,通知GC執行,但是Java語言規範並不保證GC一定會執行。

53、靜態變數和例項變數的區別?

54、什麼是java序列化,如何實現java序列化?

答:序列化就是一種用來處理物件流的機制,所謂物件流也就是將物件的內容進行流化。可以對流化後的物件進行讀寫操作,也可將流化後的物件傳輸於網路之間。序列化是為了解決在對物件流進行讀寫操作時所引發的問題。

序列化的實現:將需要被序列化的類實現Serializable介面,該介面沒有需要實現的方法,implements Serializable只是為了標註該物件是可被序列化的,然後使用一個輸出流(如:FileOutputStream)來構造一個ObjectOutputStream(物件流)物件,接著,使用ObjectOutputStream物件的writeObject(Object obj)方法就可以將引數為obj的物件寫出(即儲存其狀態),要恢復的話則用輸入流。

55、是否可以從一個static方法內部發出對非static方法的呼叫?

答:不可以,如果其中包含物件的method;不能保證物件初始化.

56、寫clone方法時,通常都有一行程式碼,是什麼?

答:Clone 有預設行為,e;他負責產生正確大小的空間,並逐位複製。

57、在JAVA中,如何跳出當前的多重巢狀迴圈?

答:用break; return 方法。

58、List、Map、Set三個介面,存取元素時,各有什麼特點?

答:List 以特定次序來持有元素,可有重複元素。Set 無法擁有重複元素,內部排序。Map 儲存key-value值,value可多值。

59、說出一些常用的類,包,介面,請各舉5個

答:常用的類:BufferedReader BufferedWriter FileReader FileWirter String Integer

常用的包:

常用的介面:Remote List Map Runnable Serializable ActionListener

二、執行緒程式設計方面

60、java中有幾種方法可以實現一個執行緒?用什麼關鍵字修飾同步方法? stop和suspend方法為何不推薦使用?

答:有兩種實現方法,分別是繼承Thread類與實現Runnable介面

用synchronized關鍵字修飾同步方法

反對使用stop,是因為它不安全。它會解除由執行緒獲取的所有鎖定,而且如果物件處於一種不連貫狀態,那麼其他執行緒能在那種狀態下檢查和修改它們。結果很難檢查出真正的問題所在。suspend方法容易發生死鎖。呼叫suspend的時候,目標執行緒會停下來,但卻仍然持有在這之前獲得的鎖定。此時,其他任何執行緒都不能訪問鎖定的資源,除非被"掛起"的執行緒恢復執行。對任何執行緒來說,如果它們想恢復目標執行緒,同時又試圖使用任何一個鎖定的資源,就會造成死鎖。所以不應該使用suspend,而應在自己的Thread類中置入一個標誌,指出執行緒應該活動還是掛起。若標誌指出執行緒應該掛起,便用wait命其進入等待狀態。若標誌指出執行緒應當恢復,則用一個notify重新啟動執行緒。

61、sleep 和 wait 有什麼區別?

答:sleep是執行緒類(Thread)的方法,導致此執行緒暫停執行指定時間,給執行機會給其他執行緒,但是監控狀態依然保持,到時後會自動恢復。呼叫sleep不會釋放物件鎖。

wait是Object類的方法,對此物件呼叫wait方法導致本執行緒放棄物件鎖,進入等待此物件的等待鎖定池,只有針對此物件發出notify方法(或notifyAll)後本執行緒才進入物件鎖定池準備獲得物件鎖進入執行狀態。

62、同步和非同步有何異同,在什麼情況下分別使用他們?舉例說明。

答:如果資料將線上程間共享。例如正在寫的資料以後可能被另一個執行緒讀到,或者正在讀的資料可能已經被另一個執行緒寫過了,那麼這些資料就是共享資料,必須進行同步存取。

當應用程式在物件上呼叫了一個需要花費很長時間來執行的方法,並且不希望讓程式等待方法的返回時,就應該使用非同步程式設計,在很多情況下采用非同步途徑往往更有效率。

63、啟動一個執行緒是用run還是start?

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

64、當一個執行緒進入一個物件的一個synchronized方法後,其它執行緒是否可進入此物件的其它方法?

答:不能,一個物件的一個synchronized方法只能由一個執行緒訪問。

65、請說出你所知道的執行緒同步的方法。

答:wait:使一個執行緒處於等待狀態,並且釋放所持有的物件的lock。

sleep:使一個正在執行的執行緒處於睡眠狀態,是一個靜態方法,呼叫此方法要捕捉InterruptedException異常。

notify:喚醒一個處於等待狀態的執行緒,注意的是在呼叫此方法的時候,並不能確切的喚醒某一個等待狀態的執行緒,而是由JVM確定喚醒哪個執行緒,而且不是按優先順序。

Allnotity:喚醒所有處入等待狀態的執行緒,注意並不是給所有喚醒執行緒一個物件的鎖,而是讓它們競爭。

66、多執行緒有幾種實現方法,都是什麼?同步有幾種實現方法,都是什麼?

答:多執行緒有兩種實現方法,分別是繼承Thread類與實現Runnable介面

同步的實現方面有兩種,分別是synchronized,wait與notify

67、執行緒的基本概念、執行緒的基本狀態以及狀態之間的關係

答:執行緒指在程式執行過程中,能夠執行程式程式碼的一個執行單位,每個程式至少都有一個執行緒,也就是程式本身。

Java中的執行緒有四種狀態分別是:執行、就緒、掛起、結束

68、簡述synchronized和的異同 ?

答:主要相同點:Lock能完成synchronized所實現的所有功能

主要不同點:Lock有比synchronized更精確的執行緒語義和更好的效能。synchronized會自動釋放鎖,而Lock一定要求程式設計師手工釋放,並且必須在finally從句中釋放。

三、Jsp方面

69、forward 和redirect的區別

答:forward是伺服器請求資源,伺服器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,然後把這些內容再發給瀏覽器,瀏覽器根本不知道伺服器傳送的內容是從哪兒來的,所以它的位址列中還是原來的地址。

redirect就是服務端根據邏輯,傳送一個狀態碼,告訴瀏覽器重新去請求那個地址,一般來說瀏覽器會用剛才請求的所有引數重新請求,所以session,request引數都可以獲取。

70、jsp有哪些內建物件?作用分別是什麼?

答:JSP共有以下9種基本內建元件(可與ASP的6種內部元件相對應):

request 使用者端請求,此請求會包含來自GET/POST請求的引數

response 網頁傳回使用者端的迴應

pageContext 網頁的屬性是在這裡管理

session 與請求有關的會話期

application servlet正在執行的內容

out 用來傳送回應的輸出

config servlet的構架部件

page JSP網頁本身

exception 針對錯誤網頁,未捕捉的例外

71、jsp有哪些動作?作用分別是什麼?

答:JSP共有以下6種基本動作:

jsp:include:在頁面被請求的時候引入一個檔案。

jsp:useBean:尋找或者例項化一個JavaBean。

jsp:setProperty:設定JavaBean的屬性。

jsp:getProperty:輸出某個JavaBean的屬性。

jsp:forward:把請求轉到一個新的頁面。

jsp:plugin:根據瀏覽器型別為Java外掛生成OBJECT或EMBED標記

72、JSP中動態INCLUDE與靜態INCLUDE的區別?

答:動態INCLUDE用jsp:include動作實現。它總是會檢查所含檔案中的變化,適合用於包含動態頁面,並且可以帶引數

靜態INCLUDE用include偽碼實現,定不會檢查所含檔案的變化,適用於包含靜態頁面:

73、兩種跳轉方式分別是什麼?有什麼區別?

答:有兩種,分別為:

前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是原來的頁面。執行完後還會回來,相當於函式呼叫。並且可以帶引數.後者完全轉向新頁面,不會再回來。相當於go to 語句。

74、JSP的內建物件及方法。

答:request表示HttpServletRequest物件。它包含了有關瀏覽器請求的資訊,並且提供了幾個用於獲取cookie, header, 和session資料的有用的方法。

response表示HttpServletResponse物件,並提供了幾個用於設定送回 瀏覽器的響應的方法(如cookies,頭資訊等)

out物件是riter的一個例項,並提供了幾個方法使你能用於向瀏覽器回送輸出結果。

pageContext表示一個Context物件。它是用於方便存取各種範圍的名字空間、servlet相關的物件的API,並且包裝了通用的servlet相關功能的方法。

session表示一個請求的Session物件。Session可以存貯使用者的狀態資訊

applicaton 表示一個letContext物件。這有助於查詢有關servlet引擎和servlet環境的資訊

config表示一個letConfig物件。該物件用於存取servlet例項的初始化引數。

page表示從該頁面產生的一個servlet例項

四、Servlet方面

75、說一說Servlet的生命週期?

答:servlet有良好的生存期的定義,包括載入和例項化、初始化、處理請求以及服務結束。這個生存期由let介面的init,service和destroy方法表達。 Servlet被伺服器例項化後,容器執行其init方法,請求到達時執行其service方法,service方法自動派遣執行與請求對應的doXXX方法(doGet,doPost)等,當伺服器決定將例項銷燬的時候呼叫其destroy方法。

與cgi的區別在於servlet處於伺服器程序中,它通過多執行緒方式執行其service方法,一個例項可以服務於多個請求,並且其例項一般不會銷燬,而CGI對每個請求都產生新的程序,服務完成後就銷燬,所以效率上低於servlet。

76、JAVA SERVLET API中forward 與redirect的區別?

答:前者僅是容器中控制權的轉向,在客戶端瀏覽器位址列中不會顯示出轉向後的地址;後者則是完全的跳轉,瀏覽器將會得到跳轉的地址,並重新發送請求連結。這樣,從瀏覽器的位址列中可以看到跳轉後的連結地址。所以,前者更加高效,在前者可以滿足需要時,儘量使用forward方法,並且,這樣也有助於隱藏實際的連結。在有些情況下,比如,需要跳轉到一個其它伺服器上的資源,則必須使用sendRedirect方法。

77、Servlet的基本架構

答:

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 {

}

}

78、什麼情況下呼叫doGet和doPost?

答:Jsp頁面中的form標籤裡的method屬性為get時呼叫doGet,為post時呼叫doPost。

79、servlet的生命週期

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

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

答:

81、頁面間物件傳遞的方法

答:request,session,application,cookie等

82、JSP和Servlet有哪些相同點和不同點,他們之間的聯絡是什麼?

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

83、四種會話跟蹤技術

答:會話作用域ServletsJSP 頁面描述

page否是代表與一個頁面相關的物件和屬性。一個頁面由一個編譯好的 Java servlet 類(可以帶有任何的 include 指令,但是沒有 include 動作)表示。這既包括 servlet 又包括被編譯成 servlet 的 JSP 頁面

request是是代表與 Web 客戶機發出的一個請求相關的物件和屬性。一個請求可能跨越多個頁面,涉及多個 Web 元件(由於 forward 指令和 include 動作的關係)

session是是代表與用於某個 Web 客戶機的一個使用者體驗相關的物件和屬性。一個 Web 會話可以也經常會跨越多個客戶機請求

application是是代表與整個 Web 應用程式相關的物件和屬性。這實質上是跨越整個 Web 應用程式,包括多個頁面、請求和會話的一個全域性作用域

84、Request物件的主要方法

答:

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):刪除請求中的一個屬性

85、我們在web應用開發過程中經常遇到輸出某種編碼的字元,如iso8859-1等,如何輸出一個某種編碼的字串?

答:

Public String translate (String str) {

String tempStr = "";

try {

tempStr = new String(ytes("ISO-8859-1"), "GBK");

tempStr = ;

}

catch (Exception e) {

tln(essage);

}

return tempStr;

}

86、Servlet執行時一般實現哪幾個方法?

答:

public void init(ServletConfig config)

public ServletConfig getServletConfig

public String getServletInfo

public void service(ServletRequest request,ServletResponse response)

public void destroy

五、Jdbc、Jdo方面

87、ame的作用?為什麼要用?

答:呼叫該訪問返回一個以字串指定類名的類的物件。

88、Jdo是什麼?

答:JDO是Java物件持久化的新的規範,為java data object的簡稱,也是一個用於存取某種資料倉庫中的物件的標準化API。JDO提供了透明的物件儲存,因此對開發人員來說,儲存資料物件完全不需要額外的程式碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中時間和精力在業務邏輯上。另外,JDO很靈活,因為它可以在任何資料底層上執行。JDBC只是面向關係資料庫(RDBMS)JDO更通用,提供到任何資料底層的儲存功能,比如關係資料庫、檔案、XML以及物件資料庫(ODBMS)等等,使得應用可移植性更強。

89、說出資料連線池的工作機制是什麼?

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

90、Jdo是什麼?

答:JDO是Java物件持久化的新的規範,為java data object的簡稱,也是一個用於存取某種資料倉庫中的物件的標準化API。JDO提供了透明的物件儲存,因此對開發人員來說,儲存資料物件完全不需要額外的程式碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中時間和精力在業務邏輯上。另外,JDO很靈活,因為它可以在任何資料底層上執行。JDBC只是面向關係資料庫(RDBMS)JDO更通用,提供到任何資料底層的儲存功能,比如關係資料庫、檔案、XML以及物件資料庫(ODBMS)等等,使得應用可移植性更強。

六、XML方面

91、xml有哪些解析技術?區別是什麼?

答:有DOM,SAX,STAX等

DOM:處理大型檔案時其效能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構佔用的記憶體較多,而且DOM必須在解析檔案之前把整個文件裝入記憶體,適合對XML的隨機訪問SAX:不現於DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML檔案,不需要一次全部裝載整個檔案。當遇到像檔案開頭,文件結束,或者標籤開頭與標籤結束時,它會觸發一個事件,使用者通過在其回撥事件中寫入處理程式碼來處理XML檔案,適合對XML的順序訪問

STAX:Streaming API for XML (StAX)

92、你在專案中用到了xml技術的哪些方面?如何實現的?

答:用到了資料存貯,資訊配置兩方面。在做資料交換平臺時,將不同資料來源的資料組裝成XML檔案,然後將XML檔案壓縮打包加密後通過網路傳送給接收者,接收解密與解壓縮後再同XML檔案中還原相關資訊進行處理。在做軟體配置時,利用XML可以很方便的進行,軟體的各種配置引數都存貯在XML檔案中。

93、XML文件定義有幾種形式?它們之間有何本質區別?解析XML文件有哪幾種方式?

答:XML文件定義有兩種形式:dtd,schema。

本質區別:schema本身是xml的,可以被XML解析器解析(這也是從DTD上發展schema的根本目的)。

解析XML文件有DOM,SAX,STAX等方式:

DOM:處理大型檔案時其效能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構佔用的記憶體較多,而且DOM必須在解析檔案之前把整個文件裝入記憶體,適合對XML的隨機訪問

SAX:不同於DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML檔案,不需要一次全部裝載整個檔案。當遇到像檔案開頭,文件結束,或者標籤開頭與標籤結束時,它會觸發一個事件,使用者通過在其回撥事件中寫入處理程式碼來處理XML檔案,適合對XML的順序訪問

STAX:Streaming API for XML (StAX)

七、EJB方面

94、EJB2.0有哪些內容?分別用在什麼場合? EJB2.0和EJB1.1的區別?

答:規範內容包括Bean提供者,應用程式裝配者,EJB容器,EJB配置工具,EJB服務提供者,系統管理員。這裡面,EJB容器是EJB之所以能夠執行的核心。EJB容器管理著EJB的建立,撤消,啟用,去活,與資料庫的連線等等重要的核心工作。JSP,Servlet,EJB,JNDI,JDBC,JMS.....

95、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元件。

96、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 的優勢卻在於他可以維持使用者的狀態。

97、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元件。

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介面。

98、EJB的角色和三個物件

答:一個完整的基於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類

99、EJB容器提供的服務

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

100、EJB規範規定EJB中禁止的操作有哪些?

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

101、remote介面和home介面主要作用

答:remote介面定義了業務方法,用於EJB客戶端呼叫業務方法。

home介面是EJB工廠用於建立和移除查詢EJB例項 102、bean 例項的生命週期

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

103、EJB的啟用機制

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

104、EJB的幾種型別

答:會話(Session)Bean ,實體(Entity)Bean 訊息驅動的(Message Driven)Bean

會話Bean又可分為有狀態(Stateful)和無狀態(Stateless)兩種

實體Bean可分為Bean管理的持續性(BMP)和容器管理的持續性(CMP)兩種

105、客服端呼叫EJB物件的幾個基本步驟

答:設定JNDI服務工廠以及JNDI服務地址系統屬性,查詢Home介面,從Home介面呼叫Create方法建立Remote介面,通過Remote介面呼叫其業務方法。

八、應用伺服器方面

106、如何給weblogic指定大小的記憶體?

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

EJB需直接實現它的業務介面或Home介面嗎,請簡述理由。

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

107、應用伺服器有那些?

答:BEA WebLogic Server,IBM WebSphere Application Server,Oracle9i Application Server,jBoss,Tomcat

108、如何設定的weblogic的熱啟動模式(開發模式)與產品釋出模式?

答:可以在管理控制檯中修改對應伺服器的啟動模式為開發或產品模式之一。或者修改服務的啟動檔案或者commenv檔案,增加set PRODUCTION_MODE=true。

109、如何啟動時不需輸入使用者名稱與密碼?

答:修改服務啟動檔案,增加 WLS_USER和WLS_PW項。也可以在erties檔案中增加加密過的使用者名稱和密碼.

110、在weblogic管理制臺中對一個應用域(或者說是一個網站,Domain)進行jms及ejb或連線池等相關資訊進行配置後,實際儲存在什麼檔案中?

答:儲存在此Domain的檔案中,它是伺服器的核心配置檔案。

111、說說weblogic中一個Domain的預設目錄結構?比如要將一個簡單的放入何目錄下,然的在瀏覽器上就可打入 http://主機:埠號//就可以看到執行結果了? 又比如這其中用到了一個自己寫的javaBean該如何辦?

答:Domain目錄伺服器目錄applications,將應用目錄放在此目錄下將可以作為應用訪問,如果是Web應用,應用目錄需要滿足Web應用目錄要求,jsp檔案可以直接放在應用目錄中,Javabean需要放在應用目錄的WEB-INF目錄的classes目錄中,設定伺服器的預設應用將可以實現在瀏覽器上無需輸入應用名。

112、在weblogic中釋出ejb需涉及到哪些配置檔案

答:不同型別的EJB涉及的配置檔案不同,都涉及到的配置檔案包括,,CMP實體Bean一般還需要

86、如何在weblogic中進行ssl配置與客戶端的認證配置或說說j2ee(標準)進行ssl的配置

答:預設安裝中使用和 KeyStore實現SSL,需要配置伺服器使用Enable SSL,配置其埠,在產品模式下需要從CA獲取私有金鑰和數字證書,建立identity和trust keystore,裝載獲得的金鑰和數字證書。可以配置此SSL連線是單向還是雙向的。

113、如何檢視在weblogic中已經發布的EJB?

答:可以使用管理控制檯,在它的Deployment中可以檢視所有已釋出的EJB

說說在weblogic中開發訊息Bean時的persistent與non-persisten的差別

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

九、J2EE及MVC方面

114、MVC的各個部分都有那些技術來實現?如何實現?

答:MVC是Model-View-Controller的簡寫。"Model" 代表的是應用的業務邏輯(通過JavaBean,EJB元件實現), "View" 是應用的表示面(由JSP頁面產生),"Controller" 是提供應用的處理過程控制(一般是一個Servlet),通過這種設計模型把應用邏輯,處理過程和顯示邏輯分成不同的元件實現。這些元件可以進行互動和重用。

115、J2EE是什麼?

答:Je22是Sun公司提出的多層(multi-diered),分散式(distributed),基於元件(component-base)的企業級應用模型(enterpriese application model).在這樣的一個應用系統中,可按照功能劃分為不同的元件,這些元件又可在不同計算機上,並且處於相應的層次(tier)中。所屬層次包括客戶層(clietn tier)元件,web層和元件,Business層和元件,企業資訊系統(EIS)層。

116、WEB SERVICE名詞解釋。JSWDL開發包的介紹。JAXP、JAXM的解釋。SOAP、UDDI,WSDL解釋。

答:Web Service描述語言WSDL

SOAP即簡單物件訪問協議(Simple Object Access Protocol),它是用於交換XML編碼資訊的輕量級協議。

UDDI 的目的是為電子商務建立標準;UDDI是一套基於Web的、分散式的、為Web Service提供的、資訊註冊中心的實現標準規範,同時也包含一組使企業能將自身提供的Web Service註冊,以使別的企業能夠發現的訪問協議的實現標準。

117、J2EE是技術還是平臺還是框架?

答:J2EE本身是一個標準,一個為企業分散式應用的開發提供的標準平臺。

J2EE也是一個框架,包括JDBC、JNDI、RMI、JMS、EJB、JTA等技術。

118、STRUTS的應用(如STRUTS架構)

答:Struts是採用Java Servlet/JavaServer Pages技術,開發Web應用程式的開放原始碼的framework。 採用Struts能開發出基於MVC(Model-View-Controller)設計模式的應用構架。 Struts有如下的主要功能:

1.包含一個controller servlet,能將使用者的請求傳送到相應的Action物件。

自由tag庫,並且在controller servlet中提供關聯支援,幫助開發員建立互動式表單應用。

3.提供了一系列實用物件:XML處理、通過Java reflection APIs自動處理JavaBeans屬性、國際化的提示和訊息。

119、WEB SERVICE名詞解釋。JSWDL開發包的介紹。JAXP、JAXM的解釋。SOAP、UDDI,WSDL解釋。

答:Web Service是基於網路的、分散式的模組化元件,它執行特定的任務,遵守具體的技術規範,這些規範使得Web Service能與其他相容的元件進行互操作。

JAXP(Java API for XML Parsing) 定義了在Java中使用DOM, SAX, XSLT的通用的介面。這樣在你的程式中你只要使用這些通用的介面,當你需要改變具體的實現時候也不需要修改程式碼。

JAXM(Java API for XML Messaging) 是為SOAP通訊提供訪問方法和傳輸機制的API。

WSDL是一種 XML 格式,用於將網路服務描述為一組端點,這些端點對包含面向文件資訊或面向過程資訊的訊息進行操作。這種格式首先對操作和訊息進行抽象描述,然後將其繫結到具體的網路協議和訊息格式上以定義端點。相關的具體端點即組合成為抽象端點(服務)。

SOAP即簡單物件訪問協議(Simple Object Access Protocol),它是用於交換XML編碼資訊的輕量級協議。

UDDI 的目的是為電子商務建立標準;UDDI是一套基於Web的、分散式的、為Web Service提供的、資訊註冊中心的實現標準規範,同時也包含一組使企業能將自身提供的Web Service註冊,以使別的企業能夠發現的訪問協議的實現標準。

120、C/S 與 B/S 區別:

答:有如下八個方面的不同:

1.硬體環境不同:

C/S 一般建立在專用的網路上, 小範圍裡的網路環境, 區域網之間再通過專門伺服器提供連線和資料交換服務.

B/S 建立在廣域網之上的, 不必是專門的網路硬體環境,例與電話上網, 租用裝置. 資訊自己管理. 有比C/S更強的適應範圍, 一般只要有作業系統和瀏覽器就行

2.對安全要求不同

C/S 一般面向相對固定的使用者群, 對資訊保安的控制能力很強. 一般高度機密的資訊系統採用C/S 結構適宜. 可以通過B/S釋出部分可公開資訊.

B/S 建立在廣域網之上, 對安全的控制能力相對弱, 可能面向不可知的使用者。

3.對程式架構不同

C/S 程式可以更加註重流程, 可以對許可權多層次校驗, 對系統執行速度可以較少考慮.

B/S 對安全以及訪問速度的多重的考慮, 建立在需要更加優化的基礎之上. 比C/S有更高的要求 B/S結構的程式架構是發展的趨勢, 從MS的系列的BizTalk 20xx Exchange 20xx等, 全面支援網路的構件搭建的系統. SUN 和IBM推的JavaBean 構件技術等,使 B/S更加成熟.

4.軟體重用不同

C/S

Tags:java 題有 筆試