當前位置:才華齋>計算機>java語言>

面試java工程師的基礎知識題「精選」

java語言 閱讀(7K)

Java程式設計師應聘一般要經過筆試和麵試。本文是本站小編搜尋整理的關於面試java工程師的基礎知識題,特別適合參加Java面試的朋友閱讀,希望對大家有所幫助!想了解更多相關資訊請持續關注我們應屆畢業生考試網!

面試java工程師的基礎知識題「精選」

  問題:如果main方法被宣告為private會怎樣?

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

  問題:Java裡的傳引用和傳值的區別是什麼?

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

  問題:如果要重寫一個物件的equals方法,還要考慮什麼?

答案:hashCode。

  問題:Java的”一次編寫,處處執行”是如何實現的?

答案:Java程式會被編譯成位元組碼組成的class檔案,這些位元組碼可以執行在任何平臺,因此Java是平臺の獨立的。

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

答案:public: main方法是Java程式執行時呼叫的第一個方法,因此它必須對Java環境可見。所以可見性設定為pulic.

static: Java平臺呼叫這個方法時不會建立這個類的一個例項,因此這個方法必須宣告為static。

void: main方法沒有返回值。

String是命令列傳進引數的型別,args是指命令列傳進的字串陣列。

  問題:==與equals的區別

答案:==比較兩個物件在記憶體裡是不是同一個物件,就是說在記憶體裡的儲存位置一致。兩個String物件儲存的值是一樣的,但有可能在記憶體裡儲存在不同的地方 .

==比較的是引用而equals方法比較的是內容。public boolean equals(Object obj) 這個方法是由Object物件提供的,可以由子類進行重寫。預設的實現只有當物件和自身進行比較時才會返回true,這個時候和==是等價的。String, BitSet, Date, 和File都對equals方法進行了重寫,對兩個String物件 而言,值相等意味著它們包含同樣的字元序列。對於基本型別的包裝類來說,值相等意味著對應的基本型別的值一樣。

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”);

tln(”== comparison : ” + (s1 == s5));

tln(”== comparison : ” + (s1 == s2));

tln(”Using equals method : ” + ls(s2));

tln(”== comparison : ” + s3 == s4);

tln(”Using equals method : ” + ls(s4));

}

}

結果:

== comparison : true

== comparison : true

Using equals method : true

false

Using equals method :true

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

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

  問題:為什麼oracle type4驅動被稱作瘦驅動?

答案:oracle提供了一個type 4 JDBC驅動,被稱為瘦驅動。這個驅動包含了一個oracle自己完全用Java實現的一個TCP/IP的Net8的實現,因此它是平臺の獨立的,可以在執行時由瀏覽器下載,不依賴任何客戶端 的oracle實現。客戶端連線字串用的是TCP/IP的地址埠,而不是資料庫名的tnsname。

  問題:介紹一下finalize方法

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

接口裡宣告的變數預設是final的。final類無法繼承,也就是沒有子類。這麼做是出於基礎型別的安全考慮,比如String和Integer。這樣也使得編譯器進行一些優化,更容易保證執行緒的安全性。final方法無法重寫。final變數的值不能改變。finalize()方法在一個物件被銷燬和回收前會被呼叫。finally,通常用於異常處理,不管有沒有異常被丟擲都會執行到。比如,關閉連線通常放到finally塊中完成。

  問題:什麼是Java API?

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

  問題:GregorianCalendar類是什麼東西?

答案:GregorianCalendar提供了西方傳統日曆的支援。

  問題:ResourceBundle類是什麼?

答案:ResourceBundle用來儲存指定語言環境的資源,應用程式可以根據執行時的語言環境來載入這些資源,從而提供不同語言的展示。

  問題:為什麼Java裡沒有全域性變數?

答案:全域性變數是全域性可見的,Java不支援全域性可見的變數,因為:全域性變數破壞了引用透明性原則。全域性變數導致了名稱空間的衝突。

  問題:如何將String型別轉化成Number型別?

答案:Integer類的valueOf方法可以將String轉成Number。下面是程式碼示例:

String numString = “1000″;

int id=eOf(numString)alue();

  問題:SimpleTimeZone類是什麼?

答案:SimpleTimeZone提供公曆日期支援。

  問題:while迴圈和do迴圈有什麼不同?

答案:while結構在迴圈的開始判斷下一個迭代是否應該繼續。do/while結構在迴圈的結尾來判斷是否將繼續下一輪迭代。do結構至少會執行一次迴圈體。

  問題:Locale類是什麼?

答案:Locale類用來根據語言環境來動態調整程式的輸出。

  問題:面向物件程式設計的原則是什麼?

答案:主要有三點,多型,繼承和封裝。

  問題:介紹下繼承的原則

答案:繼承使得一個物件可以獲取另一個物件的屬性。使用繼承可以讓已經測試完備的功能得以複用,並且可以一次修改,所有繼承的地方都同時生效。

  問題:什麼是隱式的型別轉化?

答案:隱式的型別轉化就是簡單的一個型別賦值給另一個型別,沒有顯式的告訴編譯器發生了轉化。並不是所有的型別都支援隱式的型別轉化。

程式碼示例:

int i = 1000;

long j = i; //Implicit casting

  問題:sizeof是Java的關鍵字嗎?

答案:不是。

  問題:native方法是什麼?

答案:native方法是非Java程式碼實現的方法。

  問題:在tln()裡面,System, out, println分別是什麼?

答案:System是系統提供的預定義的final類,out是一個PrintStream物件,println是out物件裡面一個過載的方法。

  問題:封裝,繼承和多型是什麼?

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

多型在Java裡有三種表現方式:方法過載通過繼承實現方法重寫通過Java介面進行方法重寫。

  問題:顯式的型別轉化是什麼?

答案:顯式的型別轉化是明確告訴了編譯器來進行物件的轉化。

程式碼示例:

long i = 700.20;

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

  問題:什麼是Java虛擬機器?

答案:Java虛擬機器是能移植到不同硬體平臺上的軟體系統。

  問題:型別向下轉換是什麼?

答案:向下轉換是指由一個通用型別轉換成一個具體的型別,在繼承結構上向下進行。

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

答案:訪問許可權修飾符是表明類成員的訪問許可權型別的關鍵字。使用這些關鍵字來限定程式的方法或者變數的訪問許可權。它們包含:

public: 所有類都可以訪問 protected: 同一個包內以及所有子類都可以訪問 private: 只有歸屬的類才能訪問預設: 歸屬類及相同包下的子類可以訪問

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

答案:Object.

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

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

  問題:靜態型別有什麼特點?

答案:靜態變數是和類繫結到一起的,而不是類的例項物件。每一個例項物件都共享同樣一份靜態變數。也就是說,一個類的靜態變數只有一份,不管它有多少個物件。類變數或者說靜態變數是通過static這個關鍵字來宣告的。類變數通常被用作常量。靜態變數通常通過類名字來進行訪問。當程式執行的時候這個變數就會建立直到程式結束後才會被銷燬。類變數的作用域和例項變數是一樣的。它的初始值和成員變數也是一樣的,當變數沒被初始化的時候根據它的資料型別,會有一個預設值。類似的,靜態方法是屬於類的方法,而不是類物件,它的呼叫並不作用於類物件,也不需要建立任何的類例項。靜態方法本身就是final的,因為重寫只會發生在類例項上,靜態方法是和類繫結在一起的,不是物件。父類的靜態方法會被子類的靜態方法遮蔽,只要原來方法沒有宣告為final。非靜態方法不能重寫靜態方法,也就是說,你不能在子類中把一個靜態方法改成例項方法。

非靜態變數在每一個物件例項上都有單獨的一份值。