




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
JAVA程序員面試題
Java基研1方面
1、作用域public,private,protected,以及不寫時的區別
答:區別如下:
作用域當前類同一package子孫類其他package
public7777
protected7V7X
friendlyVVXX
privateVXXX
不寫時默認為friendly
2>AnonymousInnerClass(匿名內部類)是否可以extends(繼承)其它類,是否可以implements(實
現)interface(接口)
答:匿名的內部類是沒有名字的內部類。不能extends(繼承)其它類,但一個內部類可以作為一個接口,由另
一個內部類實現
3、StaticNestedClass和InnerClass的不同
答:NestedClass(一般是C++的說法),InnerClass(一般是JAVA的說法)。Java內部類與C++嵌套類最大
的不同就在于是否有指向外部的引用上。注:靜態內部類(InnerClass)意味著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、Strings=newString("xyz");創建了幾個StringObject
答:兩個,一個字符對象,一個字符對象引用對象
8、Math.round(11.5)等於多少?Math.round(-11.5)等於多少
答:Math.round(11.5)==12;Math.round(-l1.5)==-11;round方法返回與參數最接近的長整數,參數加
1/2后求其floor
9、shorts1=1;s1=s1+1;有什么錯?shorts1=1;s1+=1;有什么錯
答:shortsi=1;si=si+1;(sl+1運算結果是int型,需要強制轉換類型)shortsi=1;si+=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^給我一個你最常見到的runtimeexception
答:常見的運行時異常有如下這些
ArithmeticException,ArrayStoreException,BufferOverflowException,BufferUnderf1owException,Cann
otRedoException,CannotUndoException,ClassCastException,CMMException,ConcurrentModificationExc
eption,DOMException,EmptyStackException,IllegalArgumentException,11legalMonitorStateException
,11legalPathStateException,11legalStateException,ImagingOpException,IndexOutOfBoundsException
,MissingResourceException,NegativeArraySizeException,NoSuchElementException,NulIPointerExcept
ion,Profi1eDataException,ProviderException,RasterFormatException,SecurityException,SystemExc
eption,UndeclaredThrowableException,Unmodifiab1eSetException,UnsupportedOperationException
15error和exception有什么區別
答:error表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指里程序能處理這
樣的情況
exception表示一種設計或實現問題。也就是說,它表示如果程序運行正常,從不會發生的情況
16^List,Set,Map是否繼承自Collection接口
答:List,Set是,Map不是
17、abstractclass和interface有什么區別
答:戶明方法的存在而不去實現它的類被叫做抽象類(abstractclass),它用于要創建一個體現某些基本行為
的類,并為該類聲明方法,但不能在該類中實現該類的情況。不能創建abstract類的實例。然而可以創建一個
變量,其類型是一個抽象類,并讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態方法。Abstract類
的「類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道
其行為的其它類可以在類中實現這些方法
接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過實現這樣的接口而獲得。
接口中的所有方法都是抽象的,沒有?個有程序體。接I」只可以定義staticfinal成員變量。接口的實現與子類
相似,除了該實現類不能從接口定義中繼承行為。當類實現特殊接口時,它定義(即將程序體給予)所有這種接
口的方法。然后,它可以在實現了該接口的類的任何對象上調用接口的方法。由于有抽象類,它允許使用接口名
作為引用變量的類型。通常的動態聯編將生效。引用可以轉換到接口類型或從接口類型轉換,instance"運算
符可以用來決定某對象的類是否實現了接口
18abstract的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^兩個對象值相同(x.equals(y)==true),但卻可有不同的hashcode,這句話對不對
答:不對,有相同的hashcode
25、當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么
這里到底是值傳遞還是引用傳遞
答:是值傳遞。Java編程語言只有值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就
是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的
26^swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上
答:witch(expri)中,exprl是一個整數表達式。因此傳遞給switch和case語句的參數應該
是int、short,char或者byte。long,string都不能作用于swtich
27、ArrayList和Vector的區別,HashMap和HashtabIe的區別
答:就ArrayList與Vector主要從二方面來說.
.同步性:Vector是線程安全的,也就是說是同步的,而ArrayList是線程序不安全的,不是同步的
二.數據增長:當需要增長時,Vector默認增長為原來一培,而ArrayList卻是原來的一半
就HashMap與HashTable主要從三方面來說。
歷史原因:Hashtable是基于陳舊的Dictionary類的,HashMap是Java1.2引進的Map接口的一個實現
二.同步性:Hashtable是線程安全的,也就是說是同步的,而HashMap是線程序不安全的,不是同步的
三.值:只有HashMap可以讓你將空值作為一個表的條目的key或value
28、char型變量中能不能存貯一個中文漢字?為什么?
答:是能夠定義成為一個中文的,因為java中以unicode編碼,一個char占16個字節,所以放一個中文是
沒問題的
29、GC是什么?為什么要有GC
答:GC是垃圾收集的意思(GabageCollection),內存處理是編程人員容易出現問題的地方,忘記或者錯誤的
內存回收會導致程序或系統的不穩定甚至崩潰,Java提供的GC功能可以自動監測對象是否超過作用域從而達
到自動回收內存的目的,Java語言沒有提供釋放已分配內存的顯示操作方法。
30、float型floatf=3.4是否正確?
答:不正確。精度不準確,應該用強制類型轉換,如下所示:floatf=(float)3.4
31、介紹JAVA中的CollectionFrameWork(包括如何寫自己的數據結構)?
答:CollectionFrameWork如下:
Collection
卜List
IFLinkedList
|1-ArrayList
I「Vector
ILStack
LSet
Map
|-Hashtable
|-HashMap
LWeakHashMap
Collection是最基本的集合接口,一個Collection代表一組Object,即Collection的元素(Elements)
Map提供key至ijvalue的映射
32、抽象類與接口?
答:抽象類與接口都用于抽象,但是抽象類。AVA中)可以有自己的部分實現,而接口則完全是一個標識(同時有
多重繼承的功能)。
JAVA類實現序例化的方法是實現java.io.Serializable接11
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。
java.lang.String類是final類型的,因此不可以繼承這個類、不能修改這個類。為了提高效率節省空間,我
們應該用StringBuffer類
37、int和Integer有什么區別
答:Java提供兩種不同的類型:引用類型和原始類型(或內置類型)。Int是java的原始數據類型,Integer
是java為int提供的封裝類。Java為每個原始類型提供了封裝類。
原始類型封裝
類,booleanBoolean,charCharacter,byteByte,shortShort,intlnteger,longLong,floatFloat,doubleDouble
引用類型和原始類型的行為完全不同,并且它們具有不同的語義。引用類型和原始類型具有不同的特征和用法,
它們包括:大小和速度問題,這種類型以哪種類型的數據結構存儲,當引用類型和原始類型用作某個類的實例數
據時所指定的缺省值。對象引用實例變量的缺省值為null,而原始類型實例變量的缺省值與它們的類型有關
38、運行時異常與一般異常有何異同
答:異常表示程序運行過程中可能出現的非正常狀態,運行時異常表示虛擬機的通常操作中可能遇到的異常,是
一種常見運行錯誤。java編譯器要求方法必須聲明拋出可能發生的非運行時異常,但是并不要求必須聲明拋出
未被捕獲的運行時異常。
39說出ArrayList,Vector,LinkedList的存儲性能和特性
答:ArrayList和Vector都是使用數組方式存儲數據,此數組元素數大于實際存儲的數據以便增加和插入元素,
它們都允許直接按序號索引元素,但是插入元素要涉及數組元素移動等內存操作,所以索引數據快而插入數據慢,
Vector由于使用了synchronized方法(線程安全),通常性能上較ArrayList差,而LinkedList使用雙向鏈
表實現存儲,按序號索引數據需要進行前向或后向遍歷,但是插入數據時只需要記錄本項的前后項即可,所以插
入速度較快。
40HashMap和Hashtable的區另ij
答:HashMap是Hashtable的輕量級實現(非線程安全的文現),他們都完成了Map接口,匕要區別在FHashMap
允許空(null)健值(key),由于非線程安全,效率上可能高于Hashlable。
HashMap允許將nul1作為一個entry的key或者value,而Hashtable不允許。
HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey?因為contains方法容易
讓人引起誤解。
Hashtable繼承自Dictionary類,而HashMap是Javal.2引進的Mapinterface的一個實現。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多個線程訪問Hashtable時,不需要
自己為它的方法實現同步,而HashMap就必須為之提供外同步。
Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會有很大的差異。
41heap和stack有什么區別
答:棧是一種線形集合,其添加和刪除元素的操作應在同一段完成。棧按照后進先出的方式進行處理。堆是棧的
一個組成元素
42、Java的接口和C++的虛類的相同和不同處
答:由于Java不支持多繼承,而有可能某個類或對象要使用分別在兒個類或對象里面的方法或屬性,現有的單
繼承機制就不能滿足要求。與繼承相比,接口有更高的靈活性,因為接II中沒有任何實現代碼。當個類實現了
接口以后,該類要實現接口里面所有的方法和屬性,并且接口里面的屬性在默認狀態下面都是publicstatic,
所有方法默認情況下是public.一個類可以實現多個接口。
43、Java中的異常處理機制的簡單原理和應用
答:當JAVA程序違反了JAVA的語義規則時,JAVA虛擬機就會將發生.的錯誤表不為個異常。違反語義規則包
括2種情況。-種是JAVA類庫內置的語義檢查。例如數組下標越界,會引發IndexOutOfBoundsException;訪問
nul1的對象時會引發NullPointerException。另一種情況就是JAVA允許程斤:員擴展這種語義檢查,程序員可以
創建自己的異常,并自由選擇在何時用throw關鍵字引發異常。所有的異常都是java.lang.Thowable的子類。
43、垃圾回收的優點和原理。并考慮2種回收機制
答:Java語言中一個顯著的特點就是引入了垃圾回收機制,使C++程序員最頭疼的內存管理的問題迎刃而解,它
使得Java程序員在編寫程序的時候不再需要考慮內存管理。由于有個垃圾回收機制,Java中的對象不再有''作
用域”的概念,只有對象的引用才有"作用域”。垃圾回收可以有效的防止內存泄露,有效的使用可以使用的內存。
垃圾回收器通常是作為一個單獨的低級別的線程運行,不可預知的情況下對內存堆中已經死亡的或者長時間沒有
使用的對象進行清楚和回收,程序員不能實時的調用垃圾回收器對某個對象或所有對象進行垃圾回收。回收機制
有分代復制垃圾回收和標記垃圾回收,增量垃圾回收。
44、你所知道的集合類都有哪些?主要方法?
答:最常用的集合類是List和Map。List的具體實現包括ArrayList和Vector,它們是可變大小的列表,
比較適合構建、存儲和操作任何類型對象的元素列表。List適用于按數值索引訪問元素的情形。
Map提供了一個更通用的元素存儲方法。Map集合類用于存儲元素對(稱作〃鍵"和"值"),其中每個鍵映射到
一個值。
45、描述一下JVM加載class文件的原理機制?
答:JVM中類的裝載是由ClassLoader和它的子類來實現的,JavaClassLoader是一個重要的Java運行時系統
組件。它負責在運行時查找和裝入類文件的類。
46、排序都有哪幾種方法?請列舉
答:排序的方法有:插入排序(直接插入排序、希爾排序),交換排序(冒泡排序、快速排序),選擇排序(直
接選擇排序、堆排序),歸并排序,分配排序(箱排序、基數排序)
快速排序的偽代碼。
//使用快速排序方法對a[0:n-1]排序
從@[0:n-1]中選擇一個元素作為midd1e,該元素為支點
把余下的元素分割為兩段left和right,使得1eft中的元素都小于等于支點,而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、一個"Java”源文件中是否可以包括多個類(不是內部類)?有什么限制?
答:可以。必須只有一個類名與文件名相同。
49、java中有幾種類型的流?JDK為每種類型的流提供了一些抽象類以供繼承,請說出他們分別是哪些類?
答:字節流,字符流。字節流繼承于InputStreamOutputStream,字符流繼承于
InputStreamReaderOutputStreamWriter。在java,io包中還有許多其他的流,主要是為了提高性能和使用方便。
50、java中會存在內存泄漏嗎,請簡單描述。
答:會。自己實現堆載的數據結構時有可能會出現內存泄露,可參看effectivejava.
51、java中實現多態的機制是什么?
答:方法的重寫Overriding和重載Overloading是Java多態性的不同表現。重寫Overriding是父類ij子類之
間多態性的一種表現,重載Overloading是一個類中多態性的一種表現。
52、垃圾回收器的基本原理是什么?垃圾回收器可以馬上回收內存嗎?有什么辦法主動通知虛擬機進行垃圾回
收
答:對于GC來說,當程序員創建對象時,GC就開始監控這個對象的地址、大小以及使用情況。通常,GC采用有
向圖的方式記錄和管理堆(heap)中的所有對象。通過這種方式確定哪些對象是〃可達的“,哪些對象是〃不可達的
當GC確定一些對象為“不可達"時,GC就有責任回收這些內存空間。可以。程序員可以手動執行System.gc(),
通知GC運行,但是Java語言規范并不保證GC一定會執行。
53、靜態變量和實例變量的區別?
答:statici=10;〃常量classAa;a.i=10;〃可變
54、什么是java序列化,如何實現java序列化?
答:序列化就是一種用來處理對象流的機制,所謂對象流也就是將對象的內容進行流化.可以對流化后的對象進
行讀寫操作,也可將流化后的對象傳輸「網絡之間。序列化是為了解決在對對象流進行讀寫操作時所引發的問題。
序列化的實現:將需要被序列化的類實現Serializable接口,該接口沒有需要實現的方法,
implementsSerializable只是為了標注該對象是可被序列化的,然后使用一個輸出流(如:FileOutputStream)
來構造一個ObjectOulputStream(對象流)對象,接著,使用ObjectOutputStream對象的writeObject(Objectobj)
方法就可以將參數為obj的對象寫出(即保存其狀態),要恢復的話則用輸入流。
55、是否可以從一個static方法內部發出對非static方法的調用?
答:不可以,如果其中包含對象的method。;不能保證對象初始化.
56、寫clone。方法時,通常都有一行代碼,是什么?
答:Clone有缺省行為,super,clone。;他負責產生正確大小的空間,并逐位復制。
57、在JAVA中,如何跳出當前的多重嵌套循環?
答:用break;return方法。
58、List、Map、Set三個接口,存取元素時,各有什么特點?
答:List以特定次序來持有元索,可仃重復元素。Set無法擁有重復元索,內部排序。Map保存key-value值,
value可多值。
59、說出一些常用的類,包,接口,請各舉5個
答:常用的類:BufferedReaderBufferedWriterEi1eReaderFileWirterStringInteger
常用的包:java,langjava,awtjava,iojava,utiljava,sql
常用的接口:RemoteListMapDocumentNodeList
線程編程方面
60Java中有幾種方法可以實現一個線程?用什么關鍵字修飾同步方法?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。:使一個正在運行的線程處于睡眠狀態,是??個靜態方法,調用此方法要捕捉Intei'ruptedExceplion異
常。
notify。:喚醒?個處于等待狀態的線程,注意的是在調用此方法的時候,并不能確切的喚醒某?個等待狀態的
線程,而是由JVM確定喚醒哪個線程,而且不是按優先級。
notityAll():喚醒所有處入等待狀態的線程,注意并不是給所有喚醒線程一個對象的鎖,而是讓它們競爭。
66、多線程有幾種實現方法,都是什么?同步有幾種實現方法,都是什么?
答:多線程有兩種實現方法,分別是繼承Thread類與實現Runnable接口
同步的實現方面有兩種,分別是synchronized,wait與notify
67、線程的基本概念、線程的基本狀態以及狀態之間的關系
答:線程指在程序執行過程中,能夠執行程序代碼的一個執行單位,每個程序至少都分?個線FK也就是程月;木
身。
Java中的線程有四種狀態分別是:運行、就緒、掛起、結束
68、簡述synchronized和java.util.concurrent.locks.Lock的異同?
答:主要相同點:Lock能完成synchronized所實現的所有功能
主要不同點:Lock有比synchronized更精確的線程語義和更好的性能。synchronized會自動釋放鎖,而Lock
一定要求程序員手工釋放,并且必須在finally從句中釋放。
Jsp方面
69sforward和redirect的區別
答:forward是服務器請求資源,服務器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,然后把這
些內容再發給瀏覽器,瀏覽器根本不知道服務器發送的內容是從哪兒來的,所以它的地址欄中還是原來的地址。
redirect就是服務端根據邏輯,發送一個狀態碼,告訴瀏覽器重新去請求那個地址,一般來說瀏覽器會用剛
才請求的所有參數重新請求,所以session,request參數都可以獲取。
70、jsp有哪些內置對象?作用分別是什么?
答:JSP共有以下9種基本內置組件(可與ASP的6種內部組件相對應):
request用戶端請求,此請求會包含來自GET/POST請求的參數
response網頁傳回用戶端的回應
pageContext網頁的屬性是在這里管理
session與請求有關的會話期
applicationservlet正在執行的內容
out用來傳送回應的輸出
configservlet的構架部件
pageJSP網頁本身
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動作實現
<jsp:includepage="included.jsp"flush="true"/>它總是會檢查所含文件中的變化,適合用于包含動
態頁面,并且可以帶參數
靜態INCLUDE用include偽碼實現,定不會檢查所含文件的變化,適用于包含靜態頁面
<%@includefile="included.htm"%>
73、兩種跳轉方式分別是什么?有什么區別?
答:有兩種,分別為:
<jsp:includepage="included.jsp"flush="true">
<jsp:forwardpage="nextpage.jsp"/>
前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是原來的頁面。執行完后還會回來,相
當于函數調用。并且可以帶參數.后者完全轉向新頁面,不會再回來。相當于got。語句。
74、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可以存貯用戶的狀態信息
applicator)表示一個javax.servle.ServletContext對象。這有助于查找有關servlet引擎和servlet環境的信息
config表示一■個javax.servlet.ServletConfig對象。該對象用于存取servlet實例的初始化參數。
page表示從該頁面產生的一個servlet實例
Servlet方面
75、說一說Servlet的生命周期?
答:servlet有良好的生存期的定義,包括加載和實例化、初始化、處理請求以及服務結束。這個生存期由
javax.servlet.Servlet接口的init,service和destroy方法表達。Servlet被服務器實例化后,容器運行其init
方法,請求到達時運行其service方法,service方法自動派遣運行與請求對應的doXXX方法(doGet,doPost)
等,當服務器決定將實例銷毀的時候調用其destroy方法。
與cgi的區別在于servlet處于服務器進程中,它通過多線程方式運行其service方法,一個實例可以服務于多個
請求,并且其實例一般不會銷毀,而CGI對每個請求都產生新的進程,服務完成后就銷毀,所以效率上低于servlet。
76,JAVASERVLETAPI中forward。與redirect)的區別?
答:前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向后的地址;后者則是完全的跳轉,
瀏覽器將會得到跳轉的地址,并重新發送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉后的鏈接地址。所
以,前者更加高效,在前者可以滿足需要時,盡量使用forward。方法,并且,這樣也有助于隱藏實際的鏈接。
在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用sendRedirect。方法。
77、Servlet的基本架構
答:
publicclassServletNameextendsHttpServlet{
publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throws
ServletException,lOException{
)
publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throws
ServletException,lOException{
)
)
78、什么情況下調用doGet()和doPost。?
答:Jsp頁面中的form標簽里的method屬性為get時調用doGet().為post時調用doPost()?
79、servlet的生命周期
答:web容器加載servlet,生命周期開始。通過調用servlet的init()方法進行servlet的初始化。通過調用service()
方法實現,根據請求的不同調用不同的do***()方法。結束服務,web容器調用servlet的destroy。方法。
80、如何現實servlet的單線程模式
答:<%@pageisThreadSafe="false"%>
81、頁面間對象傳遞的方法
答:request,session,application,cookie等
82、JSP和Servlet有哪些相同點和不同點,他們之間的聯系是什么?
答:JSP是Servlet技術的擴展,本質上是Servlet的簡易方式,更強調應用的外表表達。JSP編譯后是"類servlet".
Servlet和JSP最主要的不同點在于,Servlet的應用邏輯是在Java文件中,并且完全從表示層中的HTML里分
離開來。而JSP的情況是Java和HTML可以組合成一個擴展名為Jsp的文件。JSP側重于視圖,Servlet主要
用于控制邏輯。
83、四種會話跟蹤技術
答:會話作用域ServletsJSP頁面描述
page否是代表與一-個頁面相關的對象和屬性。一個頁面由?個編譯好的Javaservlet類(可以帶有任何
的include指令,但是沒有include動作)表示。這既包括servlet又包括被編譯成servlet的JSP頁面
request是是代表與Web客戶機發出的一個請求相關的對象和屬性。一個請求可能跨越多個頁面,涉及多
個Web組件(由于forward指令和include動作的關系)
session是是代表與用于某個Web客戶機的一個用戶體驗相關的對象和屬性。一個Web會話可以也經常會跨越
多個客戶機請求
application是是代表與整個Web應用程序相關的對象和屬性。這實質上是跨越整個Web應用程序,包括多個
頁面、請求和會話的一個全局作用域
84、Request對象的主要方法
答:
setAttribute(Stringname,Object):設置名字為name的request的參數值
getAttribute(Stringname):返回由name指定的屬性值
getAttributeNames():返回request對象所有屬性的名字集合,結果是一個枚舉的實例
getCookies():返回客戶端的所有Cookie對象,結果是一個Cookie數組
getCharacterEncoding():返回請求中的字符編碼方式
getContentLength():返回請求的Body的長度
getHeader(Stringname):獲得HTTP協議定義的文件頭信息
getHeaders(Stringname):返回指定名字的requestHeader的所有值,結果是一個枚舉的實例
getHeaderNames():返回所以requestHeader的名字,結果是一個枚舉的實例
getlnputStream():返回請求的輸入流,用于獲得請求中的數據
getMethod():獲得客戶端向服務器端傳送數據的方法
getParameter(Stringname):獲得客戶端傳送給服務器端的有name指定的參數值
getParameterNamesO:獲得客戶端傳送給服務器端的所有參數的名字,結果是一個枚舉的實例
getParameterValues(Stringname):獲得有name指定的參數的所有值
getProtocol():獲取客戶端向服務器端傳送數據所依據的協議名稱
getQueryString():獲得查詢字符串
getRequestURI():獲取發出請求字符串的客戶端地址
getRemoteAddr():獲取客戶端的IP地址
getRemoteHost():獲取客戶端的名字
getSession([Booleancreate]):返回和請求相關Session
getServerName():獲取服務器的名字
getServletPath():獲取客戶端所請求的腳本文件的路徑
getServerPort():獲取服務器的端口號
removeAttribute(Stringname):刪除請求中的一個屬性
85、我們在web應用開發過程中經常遇到輸出某種編碼的字符,如iso8859-1等,如何輸出一個某種編碼
的字符串?
答:
PublicStringtranslate(Stringstr){
StringtempStr=
try{
tempStr=newString(str.getBytes("ISO-8859-1"),"GBKn);
tempStr=tempStr.trim();
)
catch(Exceptione){
System.err.println(e.getMessage());
}
returntempStr;
)
86、Servlet執行時一般實現哪幾個方法?
答:
publicvoidinit(ServletConfigconfig)
publicServletConfiggetServletConfig()
publicStringgetServletlnfo()
publicvoidservice(ServletRequestrequest,ServletResponseresponse)
publicvoiddestroy()
Jdbc、Jdo方面
87、Class.forName的作用?為什么要用?
答:調用該訪問返回一個以字符串指定類名的類的對象。
88、Jdo是什么?
答:JDO是Java對象持久化的新的規范,為javadataobject的簡稱,也是一個用于存取某種數據倉庫中的對
象的標準化API。JDO提供了透明的對象存儲,因此對開發人員來說,存儲數據對象完全不需要額外的代碼(如
JDBCAPI的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中
時間和精力在業務邏輯上。另外,JDO很靈活,因為它可以在任何數據底層上運行。JDBC只是面向關系數據庫
(RDBMS)JDO更通用,提供到任何數據底層的存儲功能,比如關系數據庫、文件、XML以及對象數據庫
(ODBMS)等等,使得應用可移植性更強。
89、說出數據連接池的工作機制是什么?
答:J2EE服務器啟動時會建立一定數量的池連接,并一直維持不少于此數目的池連接。客戶端程序需要連接時,
池驅動程序會返回一個未使用的池連接并將其表記為忙。如果當前沒有空閑連接,池驅動程序就新建一定數量的
連接,新建連接的數量有配置參數決定。當使用的池連接調用完成后,池驅動程序將此連接表記為空閑,其他調
用就可以使用這個連接。
90>Jdo是什么?
答:JDO是Java對象持久化的新的規范,為javadataobject的簡稱,也是一個用于存取某種數據倉庫中的對象
的標準化API。JDO提供了透明的對象存儲,因此對開發人員來說,存儲數據對象完全不需要額外的代碼(如
JDBCAPI的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中
時間和精力在業務邏輯上。另外,JDO很靈活,因為它可以在任何數據底層上運行。JDBC只是面向關系數據庫
(RDBMS)JDO更通用,提供到任何數據底層的存儲功能,比如關系數據庫、文件、XML以及對象數據庫
(ODBMS)等等,使得應用可移植性更強。
Xml方面
91、xml有哪些解析技術?區別是什么?
答:有DOM,SAX,STAX等
DOM:處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構占用的內存較
多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問SAX:不現于DOM,SAX是事
件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。當遇到像文件開頭,文檔結
束,或者標簽開頭與標簽結束時,它會觸發一個事件,用戶通過在其回調事件中寫入處理代碼來處理XML文件,
適合對XML的順序訪問
STAXStreamingAPIforXML(StAX)
92、你在項目中用到了xml技術的哪些方面?如何實現的?
答:用到了數據存貯,信息配置兩方面。在做數據交換平臺時,將不能數據源的數據組裝成XML文件,然后將
XML文件壓縮打包加密后通過網絡傳送給接收者,接收解密與解壓縮后再同XML文件中還原相關信息進行處理。
在做軟件配置時,利用XML可以很方便的進行,軟件的各種配置參數都存貯在XML文件中。
93、XML文檔定義有幾種形式?它們之間有何本質區別?解析XML文檔有哪幾種方式?
答:a:兩種形式dtdschema,b:本質區別:schema本身是xml的,可以被XML解析器解析(這也是從DTD上
發展schema的根本Fl的),c:有DOM,SAX,STAX等
DOM:處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構占用的內存
較多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問
SAX:不現于DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。
當遇到像文件開頭,文檔結束,或者標簽開頭與標簽結束時,它會觸發一個事件,用戶通過在其回調事件中寫入
處理代碼來處理XML文件,適合對XML的順序訪問
STAX:StreamingAPIforXML(StAX)
EJB方面
94、EJB2.0有哪些內容?分別用在什么場合?EJB2.0和EJB1.1的區別?
答:規范內容包括Bean提供者,應用程序裝配者,EJB容器,EJB配置工具,EJB服務提供者,系統管理員。
這里面,EJB容器是EJB之所以能夠運行的核心。EJB容器管理著EJB的創建,撤消,激活,去活,與數據庫
的連接等等重要的核心工作。JSP,Servlet,EJBJNDI,JDBC,JMS…
95、EJB與JAVABEAN的區另ij?
答:JavaBean是可復用的組件,對JavaBean并沒有嚴格的規范,理論上講,任何一個Java類都可以是
一個Bean。但通常情況下,由于JavaBean是被容器所創建(如Tomcat)的,所以JavaBean應具有一個
無參的構造器,另夕卜,通常JavaBean還要實現Serializable接口用于實現Bean的持久性。JavaBean實
際上相當于微軟COM模型中的本地進程內COM組件,它是不能被跨進程訪問的。EnterpriseJavaBean
相當于DCOM,即分布式組件。它是基于Java的遠程方法調用(RMI)技術的,所以EJB可以被遠程訪問(跨
進程、跨計算機)。但EJB必須被布署在諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問
真正的EJB組件,而是通過其容器訪問。EJB容器是EJB組件的代理,EJB組件由容器所創建和管理。客戶通
過容器來訪問真正的EJB組件。
96、EJB是基于哪些技術實現的?并說出SessionBean和EntityBean的區別,StatefulBean和Stat
elessBean的區別。
答:EJB包括SessionBean、EntityBean.MessageDrivenBean,基于JNDI、RMI、JAT等技術實現。
SessionBean在J2EE應用程序中被用來完成一些服務器端的業務操作,例如訪問數據庫、調用其他EJB組件。
EntityBean被用來代表應用系統中用到的數據。
對于客戶機,SessionBean是一種非持久性對象,它實現某些在服務器上運行的業務邏輯。
對于客戶機,EntityBean是一種持久性對象,它代表一個存儲在持久性存儲器中的實體的對象視圖,或是一個由
現有企業應用程序實現的實體。
SessionBean還可以再細分為StatefulSessionBean與StatelessSessionBean,這兩種的SessionBean者R
可以將系統邏輯放在method之中執行,不同的是StatefulSessionBean可以記錄呼叫者的狀態,因此通常來
說,一個使用者會有一個相對應的StatefulSessionBean的實體。StatelessSessionBean雖然也是邏輯組件,
但是他卻不負責記錄使用者狀態,也就是說當使用者呼叫StatelessSessionBean的時候,EJBContainer并不
會找尋特定的StatelessSessionBean的實體來執行這個method。換言之,很可能數個使用者在執行某個Stat
elessSessionBean的methods時,會是同一個Bean的Instance在執行。從內存方面來看,StatefulSessio
nBean與StatelessSessionBean比較,StatefulSessionBean會消耗J2EEServer較多的內存,然而State
fulSessionBean的優勢卻在于他可以維持使用者的狀態。
97、EJB與JAVABEAN的區別?
答:JavaBean是可復用的組件,對JavaBean并沒有嚴格的規范,理論上講,任何一個Java類都可以是一個
Bean。但通常情況卜.,由于JavaBean是被容器所創建(如Tomcat)的,所以JavaBean應具有一個無參的
構造器,另外,通常JavaBean還要實現Se
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論