1、面向對象的特徵有哪些方面? 【基礎】
答:面向對象的特徵主要有以下幾個方面:
1)抽象:抽象就是忽略一個主題中與當前目標無關的那些方面,以便更充分地注意與當前目標有關的方面。抽象並不打算了解全部問題,而只是選擇其中的一部分,暫時不用部分細節。抽象包括兩個方面,一是過程抽象,二是數據抽象。
2)繼承:繼承是一種聯結類的層次模型,並且允許和鼓勵類的重用,它提供了一種明確表述共性的方法。對象的一個新類可以從現有的類中派生,這個過程稱為類繼承。新類繼承了原始類的特性,新類稱為原始類的派生類(子類),而原始類稱為新類的基類(父類)。派生類可以從它的基類那裡繼承方法和實例變量,並且類可以修改或增加新的方法使之更適合特殊的需要。
3)封裝:封裝是把過程和數據包圍起來,對數據的訪問只能通過已定義的界面。面向對象計算始於這個基本概念,即現實世界可以被描繪成一系列完全自治、封裝的對象,這些對象通過一個受保護的接口訪問其他對象。
4)多態性:多態性是指允許不同類的對象對同一消息作出響應。多態性包括參數化多態性和包含多態性。多態性語言具有靈活、抽象、行為共享、代碼共享的優勢,很好的解決了應用程序函數同名問題。
2、作用域public,private,protected,以及不寫時的區別?【基礎】
答:區別如下:
作用域當前類同包子孫類其他
public √ √ √ √
protected √ √ √ ×
default √ √ × ×
private √ × × ×
不寫時默認為default。
3、String是最基本的數據類型嗎? 【基礎】
答:不是。
4、float型float f=3.4是否正確? 【基礎】
答:不正確;精度不準確,應該用強制類型轉換,如下所示:float f=(float)3.4 。
5、語句float f=1.3;編譯能否通過?【基礎】
答:不能;應該用強制類型轉換,如下所示:float f=(float)1.3; 。
6、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;可以正確編譯,自動類型提升。
7、Java有沒有goto? 【基礎】
答:goto是java中的保留字,現在沒有在java中使用。
8、int和Integer有什麼區別? 【基礎】
答:Java提供兩種不同的類型:引用類型和原始類型(或內置類型);
int是java的原始數據類型,Integer是java為int提供的封裝類。
Java為每個原始類型提供了封裝類:
原始類型: boolean,char,byte,short,int,long,float,double
封裝類型:Boolean,Character,Byte,Short,Integer,Long,Float,Double引用類型和原始類型的行為完全不同,並且它們具有不同的語義。引用類型和原始類型具有不同的特徵和用法,它們包括:大小和速度問題,這種類型以哪種類型的數據結構存儲,當引用類型和原始類型用作某個類的實例數據時所指定的缺省值。對象引用實例變量的缺省值為null,而原始類型實例變量的缺省值與它們的類型有關。
9、&和&&的區別?【基礎】
答:&是位運算符,表示按位與運算,&&是邏輯運算符,表示邏輯與(and)。
10、簡述邏輯操作(&,|,^)與條件操作(&&,||)的區別?【基礎】
答:區別主要有兩點:a.條件操作只能操作布爾型的,而邏輯操作不僅可以操作布爾型,而且可以操作數值型b.邏輯操作不會產生短路。
11、heap和stack有什麼區別?【基礎】
答:棧是一種線形集合,其添加和刪除元素的操作應在同一段完成,棧按照後進先出的方式進行處理;堆是棧的一個組成元素。
12、Math.round(11.5)等於多少? Math.round(-11.5)等於多少? 【基礎】
答:Math.round(11.5)==12 Math.round(-11.5)==-11 round方法返回與參數最接近的長整數,參數加1/2後求其floor。
13、swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上? 【基礎】
答:switch(expr1)中,expr1是一個整數表達式。因此傳遞給switch和case語句的參數應該是int、short、char或者byte。long,string都不能作用於swtich。
14、編程題:用最有效率的方法算出2乘以8等於幾? 【基礎】
答: 2 << 3。
15、有沒有length這個方法? String有沒有length這個方法?【基礎】
答:數組沒有length這個方法,有length的屬性。String有length這個方法。
16、在JAVA中,如何跳出當前的多重嵌套循環?【基礎】
答:在最外層循環前加label標識,然後用break:label方法即可跳出多重循環。
17、構造器Constructor是否可被override? 【基礎】
答:構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。
18、兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對? 【基礎】
答:不對,有相同的hash code。
19、是否可以繼承String類? 【基礎】
答:String類是final類,故不可以繼承。
20、以下二條語句返回值為true的有:
A:“beijing”==“beijing”;
B:“beijing”.equalsIgnoreCase(new String(“beijing”));【基礎】
答:A和B 。
21、當一個對象被當作參數傳遞到一個方法後,此方法可改變這個對象的屬性,並可返回變化後的結果,那麼這裡到底是值傳遞還是引用傳遞? 【基礎】
答:是值傳遞。Java編程語言只有值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。
22、我們在web應用開發過程中經常遇到輸出某種編碼的字符,如iso8859-1等,如何輸出一個某種編碼的字符串?【基礎】
答:public String translate(String str){
String tempStr = "";
try{
tempStr = new String(str.getBytes("ISO-8859-1"), "GBK");
tempStr = tempStr.trim;
}catch (Exception e){
System.err.println(e.getMessage);
}
return tempStr;
}
23、String和StringBuffer的區別? 【基礎】
答:JAVA平臺提供了兩個類:String和StringBuffer,它們可以儲存和操作字符串,即包含多個字符的字符數據。這個String類提供了數值不可改變的字符串。而這個StringBuffer類提供的字符串進行修改。當你知道字符數據要改變的時候你就可以使用StringBuffer。典型地,你可以使用StringBuffers來動態構造字符數據。
24、String, StringBuffer StringBuilder的區別。【基礎】
答:String的長度是不可變的;StringBuffer的長度是可變的,如果你對字符串中的內容經常進行操作,特別是內容要修改時,那麼使用StringBuffer,如果最後需要String,那麼使用StringBuffer的toString方法;線程安全;StringBuilder是從JDK 5開始,為StringBuffer該類補充了一個單個線程使用的等價類;通常應該優先使用StringBuilder類,因為它支持所有相同的操作,但由於它不執行同步,所以速度更快。
25、Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型? 【基礎】
答:方法的重寫Overriding和重載Overloading是Java多態性的不同表現。重寫Overriding是父類與子類之間多態性的一種表現,重載Overloading是一個類中多態性的一種表現。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫(Overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被“屏蔽”了。如果在一個類中定義了多個同名的方法,它們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。
26、定義類A和類B如下:【基礎】
class A {
int a=1;
double d=2.0;
void show{
System.out.println("Class A: a="+a +" d="+d);
}
}
class B extends A{
float a=3.0f;
String d="Java program.";
void show{
super.show;
System.out.println("Class B: a="+a +" d="+d);
}
}
(1)若在應用程序的main方法中有以下語句:
A a=new A;
a.show;
則輸出的結果如何?
(2)若在應用程序的main方法中定義類B的對象b:
A b=new B;
b.show;
則輸出的結果如何?
答:輸出結果為:
1)Class A: a=1 d=2.0 ;
2)Class A: a=1 d=2.0
Class B: a=3.0 d=Java program。
27、描述一下JVM加載class文件的原理機制? 【基礎】
答:JVM中類的裝載是由ClassLoader和它的子類來實現的,Java ClassLoader是一個重要的Java運行時系統組件。它負責在運行時查找和裝入類文件的類。
28、char型變量中能不能存貯一箇中文漢字?為什麼? 【基礎】
答:能夠定義成為一箇中文的,因為java中以unicode編碼,一個char佔16個字節,所以放一箇中文是沒問題的。
29、abstract class和interface有什麼區別? 【基礎】
答:聲明方法的存在而不去實現它的類被叫做抽象類(abstract class),。然而可以創建一個變量,其類型是一個抽象類,它用於要創建一個體現某些基本行為的類,併為該類聲明方法,但不能在該類中實現該類的情況。不能創建abstract類的實例並讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態方法。Abstract類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。接口(interface)是抽象類的變體。新型多繼承性可通過實現這樣的接口而獲得。接口中的所有方法都是抽象的,所有成員變量都是publicstatic final的。一個類可以實現多個接口,當類實現特殊接口時,它定義(即
將程序體給予)所有這種接口的方法。然後,它可以在實現了該接口的類的任何對象上調用接口的方法。由於有抽象類,它允許使用接口名作為引用變量的類型。通常的動態聯編將生效。引用可以轉換到接口類型或從接口類型轉換,instanceof運算符可以用來決定某對象的類是否實現了接口。
30、Static Nested Class和Inner Class的不同?【基礎】
答:Static Nested Class是被聲明為靜態(static)的內部類,它可以不依賴於外部類實例被實例化。而通常的內部類需要在外部類實例化後才能實例化。
31、java中會存在內存洩漏嗎,請簡單描述。【基礎】
答:會;存在無用但可達的對象,這些對象不能被GC回收,導致耗費內存資源。
32、abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized? 【基礎】
答:都不能。
33、靜態變量和實例變量的區別?【基礎】
答:靜態變量也稱為類變量,歸全類共有,它不依賴於某個對象,可通過類名直接訪問;而實例變量必須依存於某一實例,只能通過對象才能訪問到它。
34、是否可以從一個static方法內部發出對非static方法的調用?【基礎】
答:不可以,如果其中包含對象的method,不能保證對象初始化。
35、寫clone方法時,通常都有一行代碼,是什麼?【基礎】
答:Clone有缺省行為:super.clone,他負責產生正確大小的空間,並逐位複製。
36、GC是什麼?為什麼要有GC? 【基礎】
答:GC是垃圾收集的意思(Gabage Collection),內存處理是編程人員容易出現問題的地方,忘記或者錯誤的內存回收會導致程序或系統的不穩定甚至崩潰,Java提供的GC功能可以自動監測對象是否超過作用域從而達到自動回收內存的目的,Java語言沒有提供釋放已分配內存的顯示操作方法。Java程序員不用擔心內存管理,因為垃圾收集器會自動進行管理。要請求垃圾收集,可以調用下面的方法之一:System.gc或Runtime.getRuntime.gc 。
37、垃圾回收的優點和原理。並考慮2種回收機制。【基礎】
答:Java語言中一個顯著的特點就是引入了垃圾回收機制,使c++程序員最頭疼的內存管理的問題迎刃而解,它使得Java程序員在編寫程序的時候不再需要考慮內存管理。由於有個垃圾回收機制,Java中的對象不再有“作用域”的概念,只有對象的引用才有“作用域”。垃圾回收可以有效的防止內存洩露,有效的使用可以使用的內存。垃圾回收器通常是作為一個單獨的低級別的線程運行,不可預知的情況下對內存堆中已經死亡的或者長時間沒有使用的對象進行清楚和回收,程序員不能實時的調用垃圾回收器對某個對象或所有對象進行垃圾回收。回收機制有分代複製垃圾回收和標記垃圾回收,增量垃圾回收。
38、垃圾回收器的基本原理是什麼?垃圾回收器可以馬上回收內存嗎?有什麼辦法主動通知虛擬機進行垃圾回收?【基礎】
答:對於GC來說,當程序員創建對象時,GC就開始監控這個對象的地址、大小以及使用情況。通常,GC採用有向圖的方式記錄和管理堆(heap)中的所有對象。通過這種方式確定哪些對象是"可達的",哪些對象是"不可達的"。當GC確定一些對象為"不可達"時,GC就有責任回收這些內存空間。可以。程序員可以手動執行System.gc,通知GC運行,但是Java語言規範並不保證GC一定會執行。
39、String s=new String(“xyz”);創建了幾個String Object? 【基礎】
答:兩個對象,一個是"xyx",一個是指向"xyx"的引用對象s。
40、接口是否可繼承接口?抽象類是否可實現(implements)接口?抽象類是否可繼承實體類(concrete class)? 【基礎】
答:接口可以繼承接口。抽象類可以實現(implements)接口,抽象類可繼承實體類,但前提是實體類必須有明確的構造函數。
41、Java的接口和C++的虛類的相同和不同處。【基礎】
答:由於Java不支持多繼承,而有可能某個類或對象要使用分別在幾個類或對象裡面的方法或屬性,現有的單繼承機制就不能滿足要求。與繼承相比,接口有更高的靈活性,因為接口中沒有任何實現代碼。當一個類實現了接口以後,該類要實現接口裡面所有的方法和屬性,並且接口裡面的屬性在默認狀態下面都是public static,所有方法默認情況下是public.一個類可以實現多個接口。
42、一個“.java”源文件中是否可以包含多個類(不是內部類)?有什麼限制?【基礎】
答:可以;必須只有一個類名與文件名相同。
43、說出一些常用的類,包,接口,請各舉5個。【基礎】
答:常用的類:BufferedReader BufferedWriter FileReader FileWirter String Integer;
常用的包:java.lang java.awt java.io java.util java.sql;
常用的接口:Remote List Map Document NodeList
44、Anonymous Inner Class (匿名內部類)是否可以extends(繼承)其它類?是否可以implements(實現)interface(接口)? 【基礎】
答:可以繼承其他類或實現其他接口,在swing 編程中常用此方式。
45、內部類可以引用他包含類的成員嗎?有沒有什麼限制?【基礎】
答:一個內部類對象可以訪問創建它的外部類對象的內容。
46、java中實現多態的機制是什麼?【基礎】
答:方法的覆蓋Overriding和重載Overloading是java多態性的不同表現;覆蓋Overriding是父類與子類之間多態性的一種表現,重載Overloading是一個類中多態性的一種表現。
47、在java中一個類被聲明為final類型,表示了什麼意思?【基礎】
答:表示該類不能被繼承,是頂級類。
48、下面哪些類可以被繼承? 【基礎】
1)java.lang.Thread (T)
2)java.lang.Number (T)
3)java.lang.Double (F)
4)java.lang.Math (F)
5)java.lang.Void (F)
6)java.lang.Class (F)
7)java.lang.ClassLoader (T)
答:1、2、7可以被繼承。
49、指出下面程序的運行結果: 【基礎】
class A{
static{
System.out.print("1");
}
public A{
System.out.print("2");
}
}
class B extends A{
static{
System.out.print("a");
}
public B{
System.out.print("b");
}
}
public class Hello{
public static void main(String ars){
A ab = new B; //執行到此處,結果: 1a2b
ab = new B; //執行到此處,結果: 1a2b2b
}
}
答:輸出結果為1a2b2b;類的static代碼段,可以看作是類首次加載(虛擬機加載)執行的代碼,而對於類加載,首先要執行其基類的構造,再執行其本身的構造。
50、繼承時候類的執行順序問題,一般都是選擇題,問你將會打印出什麼?【基礎】
父類:
package test;
public class FatherClass {
public FatherClass {
System.out.println("FatherClass Create");
}
}
子類:
package test;
import test.FatherClass;
public class ChildClass extends FatherClass {
public ChildClass {
System.out.println("ChildClass Create");
}
public static void main(String args) {
FatherClass fc = new FatherClass;
ChildClass cc = new ChildClass;
}
}
答:輸出結果為:
FatherClass Create
FatherClass Create
ChildClass Create