Java日常練習題,每天進步一點點(15)

承蒙各位厚愛,我們一起每天進步一點點!(鼠標選中空白處查看答案)

1、main 方法是 Java Application 程序執行的入口點,以下描述哪項是合法的()。

正確答案: B

public static void main( )

public static void main( String args[] )

public static int main(String [] arg )

public void main(String arg[] )

題解:
方法的名字必須是main,方法必須是public static void 類型的,方法必須接收一個字符串數組的參數 string[] args 和string args[]相同

2、一般情況下,以下哪個選項不是關系數據模型與對象模型之間匹配關系?

正確答案: D

表對應類

記錄對應對象

表的字段對應類的屬性

表之間的參考關系對應類之間的依賴關系

題解:
一般關系數據模型和對象數據模型之間有以下對應關系:表對應類,記錄對應對象,表的字段對應類的屬性。類與類之間的關系主要體現在表與表之間的關系進行操作,它們都是對對象進行操作,我們程序中把所有的表與類都映射在一起,它們通過配置文件中的many-to-one、one-to-many、many-to-many

3、下列關於修飾符混用的說法,錯誤的是( )

正確答案: D

abstract不能與final並列修飾同一個類

abstract類中不應該有private的成員

abstract方法必須在abstract類或接口中

static方法中能直接調用類裡的非static的屬性

題解:
1、abstract不能與final並列修飾同一個類 對的。
2、abstract類中不應該有private的成員 對的 :abstract類中可以有private 但是不應該有。
3、abstract方法必須在abstract類或接口中 對的 : 若類中方法有abstract修飾的,該類必須abstract修改。接口方法默認public abstract。
4、static方法中能處理非static的屬性 錯誤 :在JVM中static方法在靜態區,靜態區無法調用非靜態區屬性。

4、某程序要求每次輸入隻能是正整數,並且每次輸入的數值要求必須是100的倍數且小於等於500,則下列哪個是正確的無效等價類( )

正確答案: D

(0,100)、(100,200)、(200,300)、(300,400)、(400,500)、(500,+∞);

(500,+∞)

(500,+∞)、任意大於0小於500的非100倍數的整數;

(-∞,100)、(100,200)、(200,300)、(300,400)、(400,500)、(500,+∞);

題解:
無效等價類和有效等價類相反,即不滿足程序輸入要求或者無效的輸入數據構成的集合。

5、根據以下代碼段,下列說法中正確的是( )。

public class Parent {

private void m1(){}

void m2(){}

protected void m3(){}

public static void m4(){}

}

正確答案: C

子類中一定能夠繼承和覆蓋Parent類的m1方法

子類中一定能夠繼承和覆蓋Parent類的m2方法

子類中一定能夠繼承和覆蓋Parent類的m3方法

子類中一定能夠繼承和覆蓋Parent類的m4方法

題解:
通過繼承,子類可以擁有所有父類對其可見的方法和域
A.私有方法隻能在本類中可見,故不能繼承,A錯誤
B.缺省訪問修飾符隻在本包中可見,在外包中不可見,B錯誤
C.保護修飾符凡是繼承自該類的子類都能訪問,當然可被繼承覆蓋;C正確
D.static修飾的成員屬於類成員,父類字段或方法隻能被子類同名字段或方法遮蔽,不能被繼承覆蓋,D錯誤

6、在創建派生類對象,構造函數的執行順序()

正確答案: A

基類構造函數,派生類對象成員構造函數,派生類本身的構造函數

派生類本身的構造函數,基類構造函數,對象成員構造函數

基類構造函數,派生類本身的構造函數,派生類對象成員構造函數

對象成員構造函數,基類構造函數,派生類本身的構造函數

題解:
類的初始化過程也就是方法執行的過程。
父類的靜態域-子類的靜態域 父類的非靜態域-父類的構造函數 子類的非靜態域-子類的構造函數 規律就是 父類先於子類 靜態的先於非靜態的
其中靜態域包含靜態代碼塊與靜態方法,這個誰在前面,則先執行誰。
非靜態域同理

7、關於下面的一段代碼,以下哪些說法是正確的:

public static void main(String[] args) {
    String a = new String("myString");
    String b = "myString";
    String c = "my" + "String";
    String d = c;
    System.out.print(a == b);
    System.out.print(a == c);
    System.out.print(b == c);
    System.out.print(b == d);
}

正確答案: A D

System.out.print(a == b)打印出來的是false

System.out.print(a == c)打印出來的是true

System.out.print(b == c)打印出來的是false

System.out.print(b == d)打印出來的是true

題解:
A:a指向堆內存,b指向常量池,因此地址不相等,false
B:java有常量優化機制,c也指向常量池,且與b指向同一個,則a與c地址不相等,false;
C:b與c地址相等,true
D:d是c的副本,地址相同,所以b與d地址相等,true

8、針對以下代碼,哪些選項執行後是true的:()

class CompareReference{
   public static void main(String [] args){
   float f=42.0f;
   float f1[]=new float[2];
   float f2[]=new float[2];
   float[] f3=f1;
   long x=42;
   f1[0]=42.0f;
  }
}

正確答案: B C

f1==f2

x==f1[0]

f1==f3

f2==f1[1]

題解:
B選項:x == f1[0] ,x是long類型,與float類型對比屬於低精度,所以x要向高精度的float類型轉型再比較,故相等;
C選項:f1 == f3,f3沒有new創建,而是由f1賦值,所以f3地址是指向f1的,f1值改變,相當於改變f3值,所以相等。

9、以下哪些jvm的垃圾回收方式采用的是復制算法回收

正確答案: A D

新生代串行收集器

老年代串行收集器

並行收集器

新生代並行回收收集器

老年代並行回收收集器

cms收集器

題解:
兩個最基本的java回收算法:復制算法和標記清理算法
復制算法:兩個區域A和B,初始對象在A,繼續存活的對象被轉移到B。此為新生代最常用的算法
標記清理:一塊區域,標記可達對象(可達性分析),然後回收不可達對象,會出現碎片,那麼引出
標記-整理算法:多瞭碎片整理,整理出更大的內存放更大的對象
兩個概念:新生代和年老代
新生代:初始對象,生命周期短的
永久代:長時間存在的對象
整個java的垃圾回收是新生代和年老代的協作,這種叫做分代回收。
P.S:Serial New收集器是針對新生代的收集器,采用的是復制算法
Parallel New(並行)收集器,新生代采用復制算法,老年代采用標記整理
Parallel Scavenge(並行)收集器,針對新生代,采用復制收集算法
Serial Old(串行)收集器,新生代采用復制,老年代采用標記整理
Parallel Old(並行)收集器,針對老年代,標記整理
CMS收集器,基於標記清理
G1收集器:整體上是基於標記 整理 ,局部采用復制
綜上:新生代基本采用復制算法,老年代采用標記整理算法。cms采用標記清理。

10、局部內部類可以用哪些修飾符修飾?

正確答案: C D

public

private

abstract

final

題解:
局部內部類是放在代碼塊或方法中的,不能有訪問控制修飾符,且不能用static修飾

答案匯總:

1、正確答案: B

2、正確答案: D

3、正確答案: D

4、正確答案: D

5、正確答案: C

6、正確答案: A

7、正確答案: A D

8、正確答案: B C

9、正確答案: A D

10、正確答案: C D

總結

本篇文章就到這裡瞭,希望能給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!

推薦閱讀: