欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java方向大數(shù)據(jù)面試題與參考答案整理匯總

  發(fā)布時(shí)間:2020-01-16 14:22:05   作者:qq_27087973   我要評(píng)論
這篇文章主要介紹了java方向大數(shù)據(jù)面試題與參考答案,整理總結(jié)了java大數(shù)據(jù)方向常見面試題、知識(shí)點(diǎn)與參考答案,需要的朋友可以參考下

1.String 和StringBuffer的區(qū)別

JAVA平臺(tái)提供了兩個(gè)類:String和StringBuffer,它們可以儲(chǔ)存和操作字符串,即包含多個(gè)字符的字符數(shù)據(jù)這個(gè)String類提供了數(shù)值不可改變字符串而這個(gè)StringBuffer類提供的字符串進(jìn)行修改當(dāng)你知道字符數(shù)據(jù)要改變的時(shí)候你就可以使用StringBuffer典型地,你可以使用StringBuffers來動(dòng)態(tài)構(gòu)造字符數(shù)據(jù)

2.說出ArrayList,Vector, LinkedList的存儲(chǔ)性能和特性

     ArrayList和Vector都是使用數(shù)組方式存儲(chǔ)數(shù)據(jù),此數(shù)組元素?cái)?shù)大于實(shí)際存儲(chǔ)數(shù)據(jù)以便增加和插入元素,它們都允許直接按序號(hào)索引元素,但是插入元素要涉及數(shù)組元素移動(dòng)等內(nèi)存操作,所以索引數(shù)據(jù)快而插入數(shù)據(jù)慢,Vector由于使用了synchronized思路方法(線程安全) ,通常性能上較ArrayList差,而LinkedList使用雙向鏈表實(shí)現(xiàn)存儲(chǔ),按序號(hào)索引數(shù)據(jù)需要進(jìn)行前向或后向遍歷,但是插入數(shù)據(jù)時(shí)只需要記錄本項(xiàng)前后項(xiàng)即可,所以插入速度較快

3.HashMap和Hashtable的區(qū)別

HashMap是Hashtable的輕量級(jí)實(shí)現(xiàn)(非線程安全的實(shí)現(xiàn)),他們都完成了Map接口,主要區(qū)別在于HashMap允許空(null)鍵值(key),由于非線程安全,效率上可能高于HashtableJAVA中文站社區(qū)門戶oC)| g| ax ,HashMap允許將Null作為一個(gè)entryde key 或者value,而Hashtable不允許 HashMap把Hashtable的contains思路方法去掉了,改成containsvalue和containsKey因?yàn)閏ontains思路方法容易讓人引起誤解Hashtable繼承自Dictionary類,而HashMap是Java1.2引進(jìn)的Map interface的一個(gè)實(shí)現(xiàn)。

    最大的區(qū)別是,Hashtable的思路方法是Synchronize的,而HashMap不是,在多個(gè)線程訪問Hashtable時(shí),不需要自己為它的思路方法實(shí)現(xiàn)同步,而HashMap 就必須為的提供外同步。

    Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會(huì)有很大的差異。

4.  final, finally, finalize的區(qū)別

final 用于聲明屬性,方法和類,分別表示屬性不可變,方法不可覆蓋,類不可繼承。

finally是異常處理語句結(jié)構(gòu)的一部分,表示總是執(zhí)行。 

finalize是Object類的一個(gè)方法,在垃圾收集器執(zhí)行的時(shí)候會(huì)調(diào)用被回收對(duì)象的此方法,可以覆蓋此方法提供垃圾收集時(shí)的其他資源回收,例如關(guān)閉文件等。

5. swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?

swtich中只能用byte short int char

6. 多線程有幾種實(shí)現(xiàn)方法,都是什么?哪一種方式比較優(yōu)秀?同步有幾種實(shí)現(xiàn)方法,都是什么?

多線程有兩種實(shí)現(xiàn)方法,分別是繼承Thread類與實(shí)現(xiàn)Runnable接口 

實(shí)現(xiàn)Runnable接口比較好,因?yàn)閷?shí)現(xiàn)類可以實(shí)現(xiàn)多個(gè)接口,而只能繼承一個(gè)類。

同步的實(shí)現(xiàn)方面有兩種,分別是synchronized,wait與notify

7.  java中有幾種類型的流?JDK為每種類型的流提供了一些抽象類以供繼承,請(qǐng)說出他們分別是哪些類

字節(jié)流,字符流。字節(jié)流繼承與inputStream/outputStream,字符流繼承于inputStreamReader/outputSteamWriter。

8:如果main方法被聲明為private會(huì)怎樣?

答案:能正常編譯,但運(yùn)行的時(shí)候會(huì)提示”main方法不是public的”。

9:Java里的傳引用和傳值的區(qū)別是什么?

答案:傳引用是指?jìng)鬟f的是地址而不是值本身,傳值則是傳遞值的一份拷貝。

10:如果要重寫一個(gè)對(duì)象的equals方法,還要考慮什么?

答案:hashCode。

11:Java的”一次編寫,處處運(yùn)行”是如何實(shí)現(xiàn)的?

答案:Java程序會(huì)被編譯成字節(jié)碼組成的class文件,這些字節(jié)碼可以運(yùn)行在任何平臺(tái),因此Java是平臺(tái)獨(dú)立的。

12:說明一下public static void main(String args[])這段聲明里每個(gè)關(guān)鍵字的作用

答案:public: main方法是Java程序運(yùn)行時(shí)調(diào)用的第一個(gè)方法,因此它必須對(duì)Java環(huán)境可見。所以可見性設(shè)置為pulic.

static: Java平臺(tái)調(diào)用這個(gè)方法時(shí)不會(huì)創(chuàng)建這個(gè)類的一個(gè)實(shí)例,因此這個(gè)方法必須聲明為static。

void: main方法沒有返回值。

String是命令行傳進(jìn)參數(shù)的類型,args是指命令行傳進(jìn)的字符串?dāng)?shù)組。

13:==與equals的區(qū)別

答案:==比較兩個(gè)對(duì)象在內(nèi)存里是不是同一個(gè)對(duì)象,就是說在內(nèi)存里的存儲(chǔ)位置一致。兩個(gè)String對(duì)象存儲(chǔ)的值是一樣的,但有可能在內(nèi)存里存儲(chǔ)在不同的地方 .

==比較的是引用而equals方法比較的是內(nèi)容。public boolean equals(Object obj) 這個(gè)方法是由Object對(duì)象提供的,可以由子類進(jìn)行重寫。默認(rèn)的實(shí)現(xiàn)只有當(dāng)對(duì)象和自身進(jìn)行比較時(shí)才會(huì)返回true,這個(gè)時(shí)候和==是等價(jià)的。String, BitSet, Date, 和File都對(duì)equals方法進(jìn)行了重寫,對(duì)兩個(gè)String對(duì)象 而言,值相等意味著它們包含同樣的字符序列。對(duì)于基本類型的包裝類來說,值相等意味著對(duì)應(yīng)的基本類型的值一樣。

public class EqualsTest {
               public static void main(String[] args) {
                               String s1 = “abc”;
                               String s2 = s1;
                               String s5 = “abc”;
                               String s3 = new String(”abc”);
                               String s4 = new String(”abc”);
                               System.out.println(”== comparison : ” + (s1 == s5));
                               System.out.println(”== comparison : ” + (s1 == s2));
                               System.out.println(”Using equals method : ” + s1.equals(s2));
                               System.out.println(”== comparison : ” + s3 == s4);
                               System.out.println(”Using equals method : ” + s3.equals(s4));
               }
}

結(jié)果:

== comparison : true
== comparison : true
Using equals method : true
false
Using equals method :true

14:如果去掉了main方法的static修飾符會(huì)怎樣?

答案:程序能正常編譯。運(yùn)行時(shí)會(huì)拋NoSuchMethodError異常。

15:為什么oracle type4驅(qū)動(dòng)被稱作瘦驅(qū)動(dòng)?

答案:oracle提供了一個(gè)type 4 JDBC驅(qū)動(dòng),被稱為瘦驅(qū)動(dòng)。這個(gè)驅(qū)動(dòng)包含了一個(gè)oracle自己完全用Java實(shí)現(xiàn)的一個(gè)TCP/IP的Net8的實(shí)現(xiàn),因此它是平臺(tái)獨(dú)立的,可以在運(yùn)行時(shí)由瀏覽器下載,不依賴任何客戶端 的oracle實(shí)現(xiàn)。客戶端連接字符串用的是TCP/IP的地址端口,而不是數(shù)據(jù)庫名的tnsname。

16:介紹一下finalize方法

答案: final: 常量聲明。 finally: 處理異常。 finalize: 幫助進(jìn)行垃圾回收。

接口里聲明的變量默認(rèn)是final的。final類無法繼承,也就是沒有子類。這么做是出于基礎(chǔ)類型的安全考慮,比如String和Integer。這樣也使得編譯器進(jìn)行一些優(yōu)化,更容易保證線程的安全性。final方法無法重寫。final變量的值不能改變。finalize()方法在一個(gè)對(duì)象被銷毀和回收前會(huì)被調(diào)用。finally,通常用于異常處理,不管有沒有異常被拋出都會(huì)執(zhí)行到。比如,關(guān)閉連接通常放到finally塊中完成。

17:什么是Java API?

答案:Java API是大量軟件組件的集合,它們提供了大量有用的功能,比如GUI組件。

18:GregorianCalendar類是什么東西?

答案:GregorianCalendar提供了西方傳統(tǒng)日歷的支持。

19:ResourceBundle類是什么?

答案:ResourceBundle用來存儲(chǔ)指定語言環(huán)境的資源,應(yīng)用程序可以根據(jù)運(yùn)行時(shí)的語言環(huán)境來加載這些資源,從而提供不同語言的展示。

20:為什么Java里沒有全局變量?

答案:全局變量是全局可見的,Java不支持全局可見的變量,因?yàn)椋喝肿兞科茐牧艘猛该餍栽瓌t。全局變量導(dǎo)致了命名空間的沖突。

21:如何將String類型轉(zhuǎn)化成Number類型?

答案:Integer類的valueOf方法可以將String轉(zhuǎn)成Number。下面是代碼示例:

String numString = "1000";
int id=Integer.valueOf(numString).intValue();

22:SimpleTimeZone類是什么?

答案:SimpleTimeZone提供公歷日期支持。

23:while循環(huán)和do循環(huán)有什么不同?

答案:while結(jié)構(gòu)在循環(huán)的開始判斷下一個(gè)迭代是否應(yīng)該繼續(xù)。do/while結(jié)構(gòu)在循環(huán)的結(jié)尾來判斷是否將繼續(xù)下一輪迭代。do結(jié)構(gòu)至少會(huì)執(zhí)行一次循環(huán)體。

24:Locale類是什么?

答案:Locale類用來根據(jù)語言環(huán)境來動(dòng)態(tài)調(diào)整程序的輸出。

25:面向?qū)ο缶幊痰脑瓌t是什么?

答案:主要有三點(diǎn),多態(tài),繼承和封裝。

26:介紹下繼承的原則

答案:繼承使得一個(gè)對(duì)象可以獲取另一個(gè)對(duì)象的屬性。使用繼承可以讓已經(jīng)測(cè)試完備的功能得以復(fù)用,并且可以一次修改,所有繼承的地方都同時(shí)生效。

27:什么是隱式的類型轉(zhuǎn)化?

答案:隱式的類型轉(zhuǎn)化就是簡(jiǎn)單的一個(gè)類型賦值給另一個(gè)類型,沒有顯式的告訴編譯器發(fā)生了轉(zhuǎn)化。并不是所有的類型都支持隱式的類型轉(zhuǎn)化。

代碼示例:

int i = 1000;
long j = i; //Implicit casting

28:sizeof是Java的關(guān)鍵字嗎?

答案:不是。

29:native方法是什么?

答案:native方法是非Java代碼實(shí)現(xiàn)的方法。

30:在System.out.println()里面,System, out, println分別是什么?

答案:System是系統(tǒng)提供的預(yù)定義的final類,out是一個(gè)PrintStream對(duì)象,println是out對(duì)象里面一個(gè)重載的方法。

31:封裝,繼承和多態(tài)是什么?

答案:簡(jiǎn)單來說,多態(tài)是指一個(gè)名字多種實(shí)現(xiàn)。多態(tài)使得一個(gè)實(shí)體通過一個(gè)通用的方式來實(shí)現(xiàn)不同的操作。具體的操作是由實(shí)際的實(shí)現(xiàn)來決定的。

多態(tài)在Java里有三種表現(xiàn)方式:方法重載通過繼承實(shí)現(xiàn)方法重寫通過Java接口進(jìn)行方法重寫。

32:顯式的類型轉(zhuǎn)化是什么?

答案:顯式的類型轉(zhuǎn)化是明確告訴了編譯器來進(jìn)行對(duì)象的轉(zhuǎn)化。

代碼示例:

long i = 700.20;
int j = (int) i; //Explicit casting

33:什么是Java虛擬機(jī)?

答案:Java虛擬機(jī)是能移植到不同硬件平臺(tái)上的軟件系統(tǒng)。

34:類型向下轉(zhuǎn)換是什么?

答案:向下轉(zhuǎn)換是指由一個(gè)通用類型轉(zhuǎn)換成一個(gè)具體的類型,在繼承結(jié)構(gòu)上向下進(jìn)行。

35:Java的訪問修飾符是什么?

答案:訪問權(quán)限修飾符是表明類成員的訪問權(quán)限類型的關(guān)鍵字。使用這些關(guān)鍵字來限定程序的方法或者變量的訪問權(quán)限。它們包含:

public: 所有類都可以訪問 protected: 同一個(gè)包內(nèi)以及所有子類都可以訪問 private: 只有歸屬的類才能訪問默認(rèn): 歸屬類及相同包下的子類可以訪問

36:所有類的父類是什么?

答案:Object.

37:Java的基本類型有哪些?

答案:byte,char, short, int, long, float, double, boolean。

38:靜態(tài)類型有什么特點(diǎn)?

答案:靜態(tài)變量是和類綁定到一起的,而不是類的實(shí)例對(duì)象。每一個(gè)實(shí)例對(duì)象都共享同樣一份靜態(tài)變量。也就是說,一個(gè)類的靜態(tài)變量只有一份,不管它有多少個(gè)對(duì)象。類變量或者說靜態(tài)變量是通過static這個(gè)關(guān)鍵字來聲明的。類變量通常被用作常量。靜態(tài)變量通常通過類名字來進(jìn)行訪問。當(dāng)程序運(yùn)行的時(shí)候這個(gè)變量就會(huì)創(chuàng)建直到程序結(jié)束后才會(huì)被銷毀。類變量的作用域和實(shí)例變量是一樣的。它的初始值和成員變量也是一樣的,當(dāng)變量沒被初始化的時(shí)候根據(jù)它的數(shù)據(jù)類型,會(huì)有一個(gè)默認(rèn)值。類似的,靜態(tài)方法是屬于類的方法,而不是類對(duì)象,它的調(diào)用并不作用于類對(duì)象,也不需要?jiǎng)?chuàng)建任何的類實(shí)例。靜態(tài)方法本身就是final的,因?yàn)橹貙懼粫?huì)發(fā)生在類實(shí)例上,靜態(tài)方法是和類綁定在一起的,不是對(duì)象。父類的靜態(tài)方法會(huì)被子類的靜態(tài)方法屏蔽,只要原來方法沒有聲明為final。非靜態(tài)方法不能重寫靜態(tài)方法,也就是說,你不能在子類中把一個(gè)靜態(tài)方法改成實(shí)例方法。

非靜態(tài)變量在每一個(gè)對(duì)象實(shí)例上都有單獨(dú)的一份值。

39:&操作符和&&操作符有什么區(qū)別?

答案:當(dāng)一個(gè)&表達(dá)式在求值的時(shí)候,兩個(gè)操作數(shù)都會(huì)被求值,&&更像是一個(gè)操作符的快捷方式。當(dāng)一個(gè)&&表達(dá)式求值的時(shí)候,先計(jì)算第一個(gè)操作數(shù),如果它返回true才會(huì)計(jì)算第二個(gè)操作數(shù)。如果第一個(gè)操作數(shù)取值為fale,第二個(gè)操作數(shù)就不會(huì)被求值。

40:Java是如何處理整型的溢出和下溢的?

答案:Java根據(jù)類型的大小,將計(jì)算結(jié)果中的對(duì)應(yīng)低階字節(jié)存儲(chǔ)到對(duì)應(yīng)的值里面。

41:public static void寫成static public void會(huì)怎樣?

答案:程序正常編譯及運(yùn)行。

42,聲明變量和定義變量有什么不同?

答案:聲明變量我們只提供變量的類型和名字,并沒有進(jìn)行初始化。定義包括聲明和初始化兩個(gè)階段String s;只是變量聲明,String s = new String(“bob”); 或者String s = “bob”;是變量定義。

43:Java支持哪種參數(shù)傳遞類型?

答案:Java參數(shù)都是進(jìn)行傳值。對(duì)于對(duì)象而言,傳遞的值是對(duì)象的引用,也就是說原始引用和參數(shù)引用的那個(gè)拷貝,都是指向同一個(gè)對(duì)象。

44:對(duì)象封裝的原則是什么?

答案:封裝是將數(shù)據(jù)及操作數(shù)據(jù)的代碼綁定到一個(gè)獨(dú)立的單元。這樣保障了數(shù)據(jù)的安全,防止外部代碼的錯(cuò)誤使用。對(duì)象允許程序和數(shù)據(jù)進(jìn)行封裝,以減少潛在的干涉。對(duì)封裝的另一個(gè)理解是作為數(shù)據(jù)及代碼的保護(hù)層,防止保護(hù)層外代碼的隨意訪問。

45:你怎么理解變量?

答案:變量是一塊命名的內(nèi)存區(qū)域,以便程序進(jìn)行訪問。變量用來存儲(chǔ)數(shù)據(jù),隨著程序的執(zhí)行,存儲(chǔ)的數(shù)據(jù)也可能跟著改變。

46:數(shù)值提升是什么?

答案:數(shù)值提升是指數(shù)據(jù)從一個(gè)較小的數(shù)據(jù)類型轉(zhuǎn)換成為一個(gè)更大的數(shù)據(jù)類型,以便進(jìn)行整型或者浮點(diǎn)型運(yùn)算。在數(shù)值提升的過程中,byte,char,short值會(huì)被轉(zhuǎn)化成int類型。需要的時(shí)候int類型也可能被提升成long。long和float則有可能會(huì)被轉(zhuǎn)換成double類型。

47:Java的類型轉(zhuǎn)化是什么?

答案:從一個(gè)數(shù)據(jù)類型轉(zhuǎn)換成另一個(gè)數(shù)據(jù)類型叫做類型轉(zhuǎn)換。Java有兩種類型轉(zhuǎn)換的方式,一個(gè)是顯式的類型轉(zhuǎn)換,一個(gè)是隱式的。

48:main方法的參數(shù)里面,字符串?dāng)?shù)組的第一個(gè)參數(shù)是什么?

答案:數(shù)組是空的,沒有任何元素。不像C或者C++,第一個(gè)元素默認(rèn)是程序名。如果命令行沒有提供任何參數(shù)的話,main方法中的String數(shù)組為空,但不是null。

49:怎么判斷數(shù)組是null還是為空?

答案:輸出array.length的值,如果是0,說明數(shù)組為空。如果是null的話,會(huì)拋出空指針異常。

50:程序中可以允許多個(gè)類同時(shí)擁有都有main方法嗎?

答案:可以。當(dāng)程序運(yùn)行的時(shí)候,我們會(huì)指定運(yùn)行的類名。JVM只會(huì)在你指定的類中查找main方法。因此多個(gè)類擁有main方法并不存在命名沖突的問題。

51:靜態(tài)變量在什么時(shí)候加載?編譯期還是運(yùn)行期?靜態(tài)代碼塊加載的時(shí)機(jī)呢?

答案:當(dāng)類加載器將類加載到JVM中的時(shí)候就會(huì)創(chuàng)建靜態(tài)變量,這跟對(duì)象是否創(chuàng)建無關(guān)。靜態(tài)變量加載的時(shí)候就會(huì)分配內(nèi)存空間。靜態(tài)代碼塊的代碼只會(huì)在類第一次初始化的時(shí)候執(zhí)行一次。一個(gè)類可以有多個(gè)靜態(tài)代碼塊,它并不是類的成員,也沒有返回值,并且不能直接調(diào)用。靜態(tài)代碼塊不能包含this或者super,它們通常被用初始化靜態(tài)變量。

52:一個(gè)類能擁有多個(gè)main方法嗎?

答案:可以,但只能有一個(gè)main方法擁有以下簽名:

public static void main(String[] args) {}

否則程序?qū)o法通過編譯。編譯器會(huì)警告你main方法已經(jīng)存在。

53:簡(jiǎn)單的介紹下JVM是如何工作的?

答案:JVM是一臺(tái)抽象的計(jì)算機(jī),就像真實(shí)的計(jì)算機(jī)那樣,它們會(huì)先將.java文件編譯成.class文件(.class文件就是字節(jié)碼文件),然后用它的解釋器來加載字節(jié)碼。

54:如果原地交換兩個(gè)變量的值?

答案:先把兩個(gè)值相加賦值給第一個(gè)變量,然后用得到的結(jié)果減去第二個(gè)變量,賦值給第二個(gè)變量。再用第一個(gè)變量減去第二個(gè)變量,同時(shí)賦值給第一個(gè)變量。代碼如下:

int a=5,b=10;a=a+b; b=a-b; a=a-b;

使用異或操作也可以交換。第一個(gè)方法還可能會(huì)引起溢出。異或的方法如下: int a=5,b=10;a=a+b; b=a-b; a=a-b;

int a = 5; int b = 10;
a = a ^ b;
b = a ^ b;
a = a ^ b;

55:什么是數(shù)據(jù)的封裝?

答案:數(shù)據(jù)封裝的一種方式是在類中創(chuàng)建set和get方法來訪問對(duì)象的數(shù)據(jù)變量。一般來說變量是private的,而get和set方法是public的。封裝還可以用來在存儲(chǔ)數(shù)據(jù)時(shí)進(jìn)行數(shù)據(jù)驗(yàn)證,或者對(duì)數(shù)據(jù)進(jìn)行計(jì)算,或者用作自?。ū热缭趕truts中使用javabean)。把數(shù)據(jù)和功能封裝到一個(gè)獨(dú)立的結(jié)構(gòu)中稱為數(shù)據(jù)封裝。封裝其實(shí)就是把數(shù)據(jù)和關(guān)聯(lián)的操作方法封裝到一個(gè)獨(dú)立的單元中,這樣使用關(guān)聯(lián)的這些方法才能對(duì)數(shù)據(jù)進(jìn)行訪問操作。封裝提供的是數(shù)據(jù)安全性,它其實(shí)就是一種隱藏?cái)?shù)據(jù)的方式。

56:什么是反射API?它是如何實(shí)現(xiàn)的?

答案:反射是指在運(yùn)行時(shí)能查看一個(gè)類的狀態(tài)及特征,并能進(jìn)行動(dòng)態(tài)管理的功能。這些功能是通過一些內(nèi)建類的反射API提供的,比如Class,Method,Field, Constructors等。使用的例子:使用Java反射API的getName方法可以獲取到類名。

57:JVM自身會(huì)維護(hù)緩存嗎,是不是在堆中進(jìn)行對(duì)象分配,操作系統(tǒng)的堆還是JVM自己管理的堆?為什么?

答案:是的,JVM自身會(huì)管理緩存,它在堆中創(chuàng)建對(duì)象,然后在棧中引用這些對(duì)象。

58:虛擬內(nèi)存是什么?

答案:虛擬內(nèi)存又叫延伸內(nèi)存,實(shí)際上并不存在真實(shí)的物理內(nèi)存。

問題:方法可以同時(shí)即是static又是synchronized的嗎?

答案:可以。如果這樣做的話,JVM會(huì)獲取和這個(gè)對(duì)象關(guān)聯(lián)的java.lang.Class實(shí)例上的鎖。這樣做等于:

synchronized(XYZ.class) {
}

59:String和StringTokenizer的區(qū)別是什么?

答案:StringTokenizer是一個(gè)用來分割字符串的工具類。

StringTokenizer st = new StringTokenizer(”Hello World”);
while (st.hasMoreTokens()) {
    System.out.println(st.nextToken());
}

輸出:

Hello
World

60:transient變量有什么特點(diǎn)?

答案:transient變量不會(huì)進(jìn)行序列化。例如一個(gè)實(shí)現(xiàn)Serializable接口的類在序列化到ObjectStream的時(shí)候,transient類型的變量不會(huì)被寫入流中,同時(shí),反序列化回來的時(shí)候,對(duì)應(yīng)變量的值為null。

61:哪些容器使用Border布局作為它們的默認(rèn)布局?

答案:Window, Frame, Dialog。

62:怎么理解什么是同步?

答案:同步用來控制共享資源在多個(gè)線程間的訪問,以保證同一時(shí)間內(nèi)只有一個(gè)線程能訪問到這個(gè)資源。在非同步保護(hù)的多線程程序里面,一個(gè)線程正在修改一個(gè)共享變量的時(shí)候,可能有另一個(gè)線程也在使用或者更新它的值。同步避免了臟數(shù)據(jù)的產(chǎn)生。

對(duì)方法進(jìn)行同步:

public synchronized void Method1 () {
// Appropriate method-related code.
}

在方法內(nèi)部對(duì)代碼塊進(jìn)行同步:

public myFunction (){
    synchronized (this) {
            // Synchronized code here.
         }
}
  1. Sun HotSpot VM,是JDK和Open JDK中自帶的虛擬機(jī),也是目前使用范圍最廣的Java虛擬機(jī)。

     
  2. JVM內(nèi)存分布

    程序計(jì)數(shù)器:是一塊較小的內(nèi)存空間,可以看作是當(dāng)前線程所執(zhí)行的字節(jié)碼的行號(hào)指示器。程序中的分支、循環(huán)、跳轉(zhuǎn)、異常處理、線程恢復(fù)等基礎(chǔ)功能都需要依賴這個(gè)計(jì)數(shù)器完成。由于多線程是通過線程輪流切換并分配處理器執(zhí)行時(shí)間的方式來實(shí)現(xiàn)的,故該區(qū)域?yàn)榫€程私有的內(nèi)存。
    虛擬機(jī)棧:描述的是Java方法執(zhí)行的內(nèi)存模型,用于存儲(chǔ)局部變量表、操作數(shù)棧、動(dòng)態(tài)鏈接、方法出口等
    堆:是Java虛擬機(jī)所管理的內(nèi)存中最大的一塊,Java堆是被所有線程共享的一塊內(nèi)存區(qū)域,在虛擬機(jī)啟動(dòng)時(shí)創(chuàng)建,存放所實(shí)例,也是垃圾收集器管理的主要
    方法區(qū):用于存放已被虛擬機(jī)加載的類信息、常量、靜態(tài)變量、即時(shí)編譯后的代碼等數(shù)據(jù)。HotSVM針對(duì)該區(qū)域也進(jìn)行GC,主要是常量回收以及類

     
  3. JVM內(nèi)存分配策略
    對(duì)象的內(nèi)存分配,在大方向上,是在Java堆上進(jìn)行分配。
    大多數(shù)情況下,對(duì)象在新生代Eden區(qū)中分配,當(dāng)Eden區(qū)沒有足夠空間進(jìn)行分配時(shí),虛擬機(jī)將發(fā)起一次Minor GC。
    大多數(shù)情況下,大對(duì)象直接進(jìn)入老年代,虛擬機(jī)提供了參數(shù)來定義大對(duì)象的閥值,超過閥值的對(duì)象都會(huì)直接進(jìn)入老年代。
    經(jīng)過多次Minor GC后仍然存活的對(duì)象(長(zhǎng)期存活的對(duì)象),將進(jìn)入老年代。虛擬機(jī)提供了參數(shù),可以設(shè)置閥值。

     
  4. JVM垃圾回收算法
    標(biāo)記-清除算法:首先標(biāo)記出所有需要回收的對(duì)象,在標(biāo)記完成后統(tǒng)一回收所有被標(biāo)記的對(duì)象。
    復(fù)制算法:將可用內(nèi)存按容量劃分為大小相等的兩塊,每次只使用其中的一塊。當(dāng)一塊內(nèi)存用完了,將還存另外一塊上面,然后在把已使用過的內(nèi)存空間一次清理掉。
    標(biāo)記-整理算法:標(biāo)記過程與“標(biāo)記-清除”算法一樣,但后續(xù)步驟不是直接對(duì)可回收對(duì)象進(jìn)行清理,而是讓所一端移動(dòng),然后直接清理掉端邊界以外的內(nèi)存。
    分代收集算法:一般是把Java堆分為新生代和老年代,根據(jù)各個(gè)年代的特點(diǎn)采用最適當(dāng)?shù)氖占惴?。新生代都發(fā)現(xiàn)有大批對(duì)象死去,選用復(fù)制算法。老年代中因?yàn)閷?duì)象存活率高,必須使用“標(biāo)記-清理”或“標(biāo)記-整理”算法來進(jìn)行回收。

     
  5. 垃圾收集器
    Serial收集器:是一個(gè)單線程的收集器,只會(huì)使用一個(gè)CPU或一條收集線程去完成垃圾收集工作,在進(jìn)行垃圾收集時(shí),必須暫停其他所有的工作線程,直到它收集結(jié)束。
    ParNew收集器:是Serial收集器的多線程版本,除了使用多條線程進(jìn)行垃圾收集之外,其余行為與Serial收集器完全一樣。
    CMS收集器:是一種以獲取最短回收停頓時(shí)間為目標(biāo)的收集器。過程分為以下四個(gè)步驟:
        初始標(biāo)記
        并發(fā)標(biāo)記
        重新標(biāo)記
        并發(fā)清除

     
  6. JVM常見啟動(dòng)參數(shù)
    -Xms / -Xmx — 堆的初始大小 / 堆的最大大小
    -Xmn — 堆中年輕代的大小
    -XX:-DisableExplicitGC — 讓System.gc()不產(chǎn)生任何作用
    -XX:+PrintGCDetails — 打印GC的細(xì)節(jié)
    -XX:+PrintGCDateStamps — 打印GC操作的時(shí)間戳
    -XX:NewSize / XX:MaxNewSize — 設(shè)置新生代大小/新生代最大大小
    -XX:NewRatio — 可以設(shè)置老生代和新生代的比例
    -XX:PrintTenuringDistribution — 設(shè)置每次新生代GC后輸出幸存者樂園中對(duì)象年齡的分布
    -XX:InitialTenuringThreshold / -XX:MaxTenuringThreshold:設(shè)置老年代閥值的初始值和最大值
    -XX:TargetSurvivorRatio:設(shè)置幸存區(qū)的目標(biāo)使用率

     
  7. JAVA類生命周期
    Java類從被加載到虛擬機(jī)內(nèi)存中開始,到卸載出內(nèi)存為止,它的整個(gè)生命周期包括:加載、驗(yàn)證、準(zhǔn)備、解析、初始化、使用、卸載七個(gè)階段。

     
  8. JVM類加載
    啟動(dòng)(Bootstrap)類加載器:是用本地代碼實(shí)現(xiàn)的類裝入器,它負(fù)責(zé)將 <Java_Runtime_Home>/lib下面的類庫加載到內(nèi)存中(比如rt.jar)。由于引導(dǎo)類加載器涉及到虛擬機(jī)本地實(shí)現(xiàn)細(xì)節(jié),開發(fā)者無法直接獲取到啟動(dòng)類加載器的引用,所以不允許直接通過引用進(jìn)行操作。
    標(biāo)準(zhǔn)擴(kuò)展(Extension)類加載器:是由 Sun 的 ExtClassLoader(sun.misc.Launcher$ExtClassLoader)實(shí)現(xiàn)Java_Runtime_Home >/lib/extjava.ext.dir指定位置中的類庫加載到內(nèi)存中。開發(fā)者可以直接使用標(biāo)準(zhǔn)擴(kuò)展類加載器。
    系統(tǒng)(System)類加載器:是由 Sun 的 AppClassLoader(sun.misc.Launcher$AppClassLoader)實(shí)現(xiàn)的。徑(CLASSPATH)中指定的類庫加載到內(nèi)存中。開發(fā)者可以直接使用系統(tǒng)類加
    雙親委派機(jī)制描述 :某個(gè)特定的類加載器在接到加載類的請(qǐng)求時(shí),首先將加載任務(wù)委托給父類加載器,依次遞歸,如果父類加載器可以完成類加載任務(wù),就成功返回;只有父類加載器無法完成此加載任務(wù)時(shí),才自己去加載。

     
  9. JVM調(diào)優(yōu)
    查看堆空間大小分配(年輕代、年老代、持久代分配)
    垃圾回收監(jiān)控(長(zhǎng)時(shí)間監(jiān)控回收情況)
    線程信息監(jiān)控:系統(tǒng)線程數(shù)量
    線程狀態(tài)監(jiān)控:各個(gè)線程都處在什么樣的狀態(tài)下
    線程詳細(xì)信息:查看線程內(nèi)部運(yùn)行情況,死鎖檢查
    CPU熱點(diǎn):檢查系統(tǒng)哪些方法占用了大量CPU時(shí)間
    內(nèi)存熱點(diǎn):檢查哪些對(duì)象在系統(tǒng)中數(shù)量最大

相關(guān)文章

最新評(píng)論