成年人在线观看视频免费,国产第2页,人人狠狠综合久久亚洲婷婷,精品伊人久久

我要投稿 投訴建議

經(jīng)典的Java基礎(chǔ)面試題

時間:2022-11-03 10:33:50 面試試題 我要投稿
  • 相關(guān)推薦

經(jīng)典的Java基礎(chǔ)面試題集錦

  下面CNrencai網(wǎng)小編分享一些經(jīng)典的Java基礎(chǔ)面試題,歡迎收藏和分享。

經(jīng)典的Java基礎(chǔ)面試題集錦

  問題:如果main方法被聲明為private會怎樣?

  答案:能正常編譯,但運行的時候會提示”main方法不是public的”。

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

  答案:傳引用是指傳遞的是地址而不是值本身,傳值則是傳遞值的一份拷貝。

  問題:如果要重寫一個對象的equals方法,還要考慮什么?

  答案:hashCode。

  問題:Java的”一次編寫,處處運行”是如何實現(xiàn)的?

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

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

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

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

  void: main方法沒有返回值。

  String是命令行傳進參數(shù)的類型,args是指命令行傳進的字符串數(shù)組。

  問題:==與equals的區(qū)別

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

  ==比較的是引用而equals方法比較的是內(nèi)容。public boolean equals(Object obj) 這個方法是由Object對象提供的,可以由子類進行重寫。默認的實現(xiàn)只有當對象和自身進行比較時才會返回true,這個時候和==是等價的。String, BitSet, Date, 和File都對equals方法進行了重寫,對兩個String對象 而言,值相等意味著它們包含同樣的字符序列。對于基本類型的包裝類來說,值相等意味著對應(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

  問題:如果去掉了main方法的static修飾符會怎樣?

  答案:程序能正常編譯。運行時會拋NoSuchMethodError異常。

  問題:為什么oracle type4驅(qū)動被稱作瘦驅(qū)動?

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

  問題:介紹一下finalize方法

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

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

  問題:什么是Java API?

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

  問題:GregorianCalendar類是什么東西?

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

  問題:ResourceBundle類是什么?

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

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

  答案:全局變量是全局可見的,Java不支持全局可見的變量,因為:全局變量破壞了引用透明性原則。全局變量導(dǎo)致了命名空間的沖突。

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

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

  String numString = “1000″;

  int id=Integer.valueOf(numString).intValue();

  問題:SimpleTimeZone類是什么?

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

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

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

  問題:Locale類是什么?

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

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

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

  問題:介紹下繼承的原則

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

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

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

  代碼示例:

  int i = 1000;

  long j = i; //Implicit casting

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

  答案:不是。

  問題:native方法是什么?

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

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

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

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

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

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

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

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

  代碼示例:

  long i = 700.20;

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

  問題:什么是Java虛擬機?

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

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

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

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

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

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

  問題:所有類的父類是什么?

  答案:Object.

  問題:Java的基本類型有哪些?

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

  問題:靜態(tài)類型有什么特點?

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

  非靜態(tài)變量在每一個對象實例上都有單獨的一份值。

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

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

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

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

  問題:public static void寫成static public void會怎樣?

  答案:程序正常編譯及運行。

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

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

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

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

  問題:對象封裝的原則是什么?

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

  問題:你怎么理解變量?

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

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

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

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

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

  問題:main方法的參數(shù)里面,字符串數(shù)組的第一個參數(shù)是什么?

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

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

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

  問題:程序中可以允許多個類同時擁有都有main方法嗎?

  答案:可以。當程序運行的時候,我們會指定運行的類名。JVM只會在你指定的類中查找main方法。因此多個類擁有main方法并不存在命名沖突的問題。

  問題:靜態(tài)變量在什么時候加載?編譯期還是運行期?靜態(tài)代碼塊加載的時機呢?

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

  問題:一個類能擁有多個main方法嗎?

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

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

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

  問題:簡單的介紹下JVM是如何工作的?

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

  問題:如果原地交換兩個變量的值?

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

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

  使用異或操作也可以交換。第一個方法還可能會引起溢出。異或的方法如下: 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;

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

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

  問題:什么是反射API?它是如何實現(xiàn)的?

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

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

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

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

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

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

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

  synchronized(XYZ.class) {

  }

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

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

  StringTokenizer st = new StringTokenizer(”Hello World”);

  while (st.hasMoreTokens()) {

  System.out.println(st.nextToken());

  }

  輸出:

  Hello

  World

  問題:transient變量有什么特點?

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

  問題:哪些容器使用Border布局作為它們的默認布局?

  答案:Window, Frame, Dialog。

  問題:怎么理解什么是同步?

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

  對方法進行同步:

  public synchronized void Method1 () {

  // Appropriate method-related code.

  }

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

  public myFunction (){

  synchronized (this) {

  // Synchronized code here.

  }

  }

【經(jīng)典的Java基礎(chǔ)面試題】相關(guān)文章:

Java經(jīng)典面試題12-29

Java面試題01-22

java學習:Java面試題和答案07-17

Java框架面試題07-16

瞬聯(lián)java面試題03-26

java線程面試題匯總02-22

2016高薪Java面試題02-20

ios基礎(chǔ)面試題08-07

Java Web基礎(chǔ)筆試題09-26

java工程師面試題09-25