<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • java面試題

    時間:2024-08-11 09:00:55 面試筆試 我要投稿

    java面試題2014

      Java面試題2014

    java面試題2014

      1.C++或Java中的異常處理機制的簡單原理和應用。

      當JAVA程序違反了JAVA的語義規則時,JAVA虛擬機就會將發生的錯誤表示為一個異常。違反語義規則包括2種情況。一種是JAVA類庫內置的語義檢查。例如數組下標越界,會引發IndexOutOfBoundsException;訪問null的對象時會引發NullPointerException。另一種情況就是JAVA允許程序員擴展這種語義檢查,程序員可以創建自己的異常,并自由選擇在何時用throw關鍵字引發異常。所有的異常都是java.lang.Thowable的子類。

      2. Java的接口和C++的虛類的相同和不同處。

      由于Java不支持多繼承,而有可能某個類或對象要使用分別在幾個類或對象里面的方法或屬性,現有的單繼承機制就不能滿足要求。與繼承相比,接口有更高的靈活性,因為接口中沒有任何實現代碼。當一個類實現了接口以后,該類要實現接口里面所有的方法和屬性,并且接口里面的屬性在默認狀態下面都是public static,所有方法默認情況下是public.一個類可以實現多個接口。

      3. 垃圾回收的優點和原理。并考慮2種回收機制。

      Java語言中一個顯著的特點就是引入了垃圾回收機制,使c++程序員最頭疼的內存管理的問題迎刃而解,它使得Java程序員在編寫程序的時候不再需要考慮內存管理。由于有個垃圾回收機制,Java中的對象不再有“作用域”的概念,只有對象的引用才有“作用域”。垃圾回收可以有效的防止內存泄露,有效的使用可以使用的內存。垃圾回收器通常是作為一個單獨的低級別的線程運行,不可預知的情況下對內存堆中已經死亡的或者長時間沒有使用的對象進行清楚和回收,程序員不能實時的調用垃圾回收器對某個對象或所有對象進行垃圾回收。回收機制有分代復制垃圾回收和標記垃圾回收,增量垃圾回收。

      4. 請說出你所知道的線程同步的方法。

      wait():使一個線程處于等待狀態,并且釋放所持有的對象的lock。

      sleep():使一個正在運行的線程處于睡眠狀態,是一個靜態方法,調用此方法要捕捉InterruptedException異常。

      notify():喚醒一個處于等待狀態的線程,注意的是在調用此方法的時候,并不能確切的喚醒某一個等待狀態的線程,而是由JVM確定喚醒哪個線程,而且不是按優先級。

      Allnotity():喚醒所有處入等待狀態的線程,注意并不是給所有喚醒線程一個對象的鎖,而是讓它們競爭。

      5. 請講一講析構函數和虛函數的用法和作用。

      6. Error與Exception有什么區別?

      Error表示系統級的錯誤和程序不必處理的異常,

      Exception表示需要捕捉或者需要程序進行處理的異常。

      7. 在java中一個類被聲明為final類型,表示了什么意思?

      表示該類不能被繼承,是頂級類。

      8. 描述一下你最常用的編程風格。

      9. heap和stack有什么區別。

      棧是一種線形集合,其添加和刪除元素的操作應在同一段完成。棧按照后進先出的方式進行處理。

      堆是棧的一個組成元素

      10. 如果系統要使用超大整數(超過long長度范圍),請你設計一個數據結構來存儲這種超大型數字以及設計一種算法來實現超大整數加法運算)。

      public class BigInt()

      {

      int[] ArrOne = new ArrOne[1000];

      String intString="";

      public int[] Arr(String s)

      {

      intString = s;

      for(int i=0;i

      {

      11. 如果要設計一個圖形系統,請你設計基本的圖形元件(Point,Line,Rectangle,Triangle)的簡單實現

      第一,談談final, finally, finalize的區別。

      final 用于聲明屬性,方法和類,分別表示屬性不可變,方法不可覆蓋,類不可繼承。finally是異常處理語句結構的一部分,表示總是執行。finalize是 Object類的一個方法,在垃圾收集器執行的時候會調用被回收對象的此方法,可以覆蓋此方法提供垃圾收集時的其他資源回收,例如關閉文件等。

      第二,Anonymous Inner Class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現)interface(接口)?

      可以繼承其他類或完成其他接口,在swing編程中常用此方式。

      第三,Static Nested Class 和 Inner Class的不同,說得越多越好(面試題有的很籠統)。

      Static Nested Class是被聲明為靜態(static)的內部類,它可以不依賴于外部類實例被實例化。而通常的內部類需要在外部類實例化后才能實例化。

      第四,&和&&的區別。

      &是位運算符,表示按位與運算,&&是邏輯運算符,表示邏輯與(and).

      第五,HashMap和Hashtable的區別。

      HashMap是Hashtable的輕量級實現(非線程 安全 的實現),他們都完成了Map接口,主要區別在于HashMap允許空(null)鍵值(key),由于非線程 安全 ,效率上可能高于Hashtable.

      第六,Collection 和 Collections的區別。

      Collection是集合類的上級接口,繼承與他的接口主要有Set 和List.Collections是針對集合類的一個幫助類,他提供一系列靜態方法實現對各種集合的搜索、排序、線程安全化等操作。

      第七,什么時候用assert。

      1.4新增關鍵字(語法),用于測試boolean表達式狀態,可用于調試程序。使用方法 assert ,表示如果表達式為真(true),則下面的語句執行,否則拋出AssertionError。另外的使用方式assert < boolean表達式>:,表示如果表達式為真,后面的表達式忽略,否則后面表達式的值用于AssertionError的構建參數。注意編譯時要增加-source 1.4 參數,否則報錯。]運行時要增加 –ea參數,否則assert行被忽略

      第八,GC是什么? 為什么要有GC?

      GC是垃圾收集的意思(Gabage Collection),內存處理是編程人員容易出現問題的地方,忘記或者錯誤的內存回收會導致程序或系統的不穩定甚至崩潰, Java 提供的GC功能可以 自動監測對象是否超過作用域從而達到自動回收內存的目的, Java 語言沒有提供釋放已分配內存的顯示操作方法。

      第九,String s = new String("xyz");創建了幾個String Object?

      兩個

      第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少?

      Math.round(11.5)==12Math.round(-11.5)==-11round方法返回與參數最接近的長整數,參數加1/2后求其floor.

      第十一,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;(可以正確編譯)

      第十二,sleep() 和 wait() 有什么區別?

      sleep是線程類(Thread)的方法,導致此線程暫停執行指定時間,給執行機會給其他線程,但是監控狀態依然保持,到時后會自動恢復。調用 sleep不會釋放對象鎖。wait是Object類的方法,對此對象調用wait方法導致本線程放棄對象鎖,進入等待此對象的等待鎖定池,只有針對此對 象發出notify方法(或notifyAll)后本線程才進入對象鎖定池準備獲得對象鎖進入運行狀態。

      第十三、

      多線程是為了同步完成多項任務,不是為了提供運行效率,通過提高資源使用效率來提高系統的效率. 線程是在同一時間需要完成多項任務的時候實現的.

      可以完成同時運行,但是通過程序運行的結果發現,雖然同時運行,但是每一次結果都不一致。

      因為多線程存在一個特性:隨機性。

      造成的原因:CPU在瞬間不斷切換去處理各個線程而導致的。

      可以理解成多個線程在搶cpu資源。

      2、 線程與進程的比較

      線程具有許多傳統進程所具有的特征,故又稱為輕型進程(Light—Weight Process)或進程元;

      而把傳統的進程稱為重型進程(Heavy—Weight Process),它相當于只有一個線程的任務。在引入了線程的操作系統中,通常一個進程都有若干個線程,至少需要一個線程。

      進程與線程的區別:

      1.進程有獨立的進程空間,進程中的數據存放空間(堆空間和棧空間)是獨立的。

      2.線程的堆空間是共享的,棧空間是獨立的,線程消耗的資源也比進程小,相互之間可以影響的

      第十三,Java有沒有goto?

      沒有 很十三的問題,如果哪個面試的問到這個問題,我勸你還是別進這家公司。

      第十四,數組有沒有length()這個方法? String有沒有length()這個方法?

      數組沒有length()這個方法,有length的屬性。

      String有有length()這個方法。

      第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類型?

      方法的重寫Overriding和重載Overloading是Java多態性的不同表現。重寫Overriding是父類與子類之間多態性的一種表現, 重載Overloading是一個類中多態性的一種表現。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫 (Overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被“屏蔽”了。如果在一個類中定義了多個同名的方 法,它們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。

      第十六,Set里的元素是不能重復的,那么用什么方法來區分重復與否呢? 是用==還是equals()? 它們有何區別?

      Set里的元素是不能重復的,那么用iterator()方法來區分重復與否。equals()是判讀兩個Set是否相等。

      equals()和==方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當兩個分離的對象的內容和類型相配的話,返回真值。

      第十七,給我一個你最常見到的runtime exception。

    [next]

      參考如下:

      ArithmeticException,

      ArrayStoreException,

      BufferOverflowException,

      BufferUnderflowException,

      CannotRedoException,

      CannotUndoException,

      ClassCastException,

      CMMException,

      ConcurrentModificationException,

      DOMException,

      EmptyStackException,

      IllegalArgumentException,

      IllegalMonitorStateException,

      IllegalPathStateException,

      IllegalStateException,

      ImagingOpException,

      IndexOutOfBoundsException,

      MissingResourceException,

      NegativeArraySizeException,

      NoSuchElementException,

      NullPointerException,

      ProfileDataException,

      ProviderException,

      RasterFormatException,

      SecurityException,

      SystemException,

      UndeclaredThrowableException,

      UnmodifiableSetException,

      UnsupportedOperationException

      第十八,error和exception有什么區別?

      error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指望程序能處理這樣的情況。

      exception 表示一種設計或實現問題。也就是說,它表示如果程序運行正常,從不會發生的情況。

      第十九,List, Set, Map是否繼承自Collection接口?

      List,Set是

      Map不是

      第二十,abstract class和interface有什么區別?

      聲明方法的存在而不去實現它的類被叫做抽象類(abstract class),它用于要創建一個體現某些基本行為的類,并為該類聲明方法,但不能在該類中實現該類的情況。不能創建abstract 類的實例。然而可以創建一個變量,其類型是一個抽象類,并讓它指向具體子類的一個實例。不能有抽象構造函數或抽象靜態方法。Abstract 類的子類為它們父類中的所有抽象方法提供實現,否則它們也是抽象類為。取而代之,在子類中實現該方法。知道其行為的其它類可以在類中實現這些方法。

      接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過實現這樣的接口而獲得。接口中的所有方法都是抽象的,沒有一個 有程序體。接口只可以定義static final成員變量。接口的實現與子類相似,除了該實現類不能從接口定義中繼承行為。當類實現特殊接口時,它定義(即將程序體給予)所有這種接口的方法。 然后,它可以在實現了該接口的類的任何對象上調用接口的方法。由于有抽象類,它允許使用接口名作為引用變量的類型。通常的動態聯編將生效。引用可以轉換到 接口類型或從接口類型轉換,instanceof 運算符可以用來決定某對象的類是否實現了接口。

      第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized?

      都不能

      第二十二,接口是否可繼承接口? 抽象類是否可實現(implements)接口? 抽象類是否可繼承實體類(concrete class)?

      接口可以繼承接口。抽象類可以實現(implements)接口,抽象類是否可繼承實體類,但前提是實體類必須有明確的構造函數。

      第二十三,啟動一個線程是用run()還是start()?

      啟動一個線程是調用start()方法,使線程所代表的虛擬處理機處于可運行狀態,這意味著它可以由JVM調度并執行。這并不意味著線程就會立即運行。run()方法可以產生必須退出的標志來停止一個線程。

      第二十四,構造器Constructor是否可被override?

      構造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。

      第二十五,是否可以繼承String類?

      String類是final類故不可以繼承。

      第二十六,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法?

      不能,一個對象的一個synchronized方法只能由一個線程訪問。

      第二十七,try {}里有一個return語句,那么緊跟在這個try后的finally {}里的code會不會被執行,什么時候被執行,在return前還是后?

      會執行,在return前執行。

      第二十八,編程題: 用最有效率的方法算出2乘以8等於幾?

      有C背景的程序員特別喜歡問這種問題。

      2 << 3

      第二十九,兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對?

      不對,有相同的hash code。

      第三十,當一個對象被當作參數傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞?

      是值傳遞。Java 編程語言只由值傳遞參數。當一個對象實例作為一個參數被傳遞到方法中時,參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。

      第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?

      switch(expr1)中,expr1是一個整數表達式。因此傳遞給 switch 和 case 語句的參數應該是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。

      第三十二,編程題: 寫一個Singleton出來。

      Singleton模式主要作用是保證在Java應用程序中,一個類Class只有一個實例存在。

      一般Singleton模式通常有幾種種形式:

      第一種形式: 定義一個類,它的構造函數為private的,它有一個static的private的該類變量,在類初始化時實例話,通過一個public的getInstance方法獲取對它的引用,繼而調用其中的方法。

      public class Singleton {

      private Singleton(){}

      //在自己內部定義自己一個實例,是不是很奇怪?

      //注意這是private 只供內部調用

      private static Singleton instance = new Singleton();

      //這里提供了一個供外部訪問本class的靜態方法,可以直接訪問

      public static Singleton getInstance() {

      return instance;

      }

      }

      第二種形式:

      public class Singleton {

      private static Singleton instance = null;

      public static synchronized Singleton getInstance() {

      //這個方法比上面有所改進,不用每次都進行生成對象,只是第一次

      //使用時生成實例,提高了效率!

      if (instance==null)

      instance=new Singleton();

      return instance; }

      }

      其他形式:

      定義一個類,它的構造函數為private的,所有方法為static的。

      一般認為第一種形式要更加安全些

    【java面試題】相關文章:

    Java面試的面試題目與解題思路 201411-20

    2017年java中高級筆試面試題及答案11-11

    面試題精選02-18

    分享面試題目 教育職業面試題11-20

    熱門就業行業面試題精選:編輯行業面試題!11-19

    Microsoft 面試題11-19

    蘋果 面試題11-19

    熱門就業行業面試題精選 銷售行業面試題11-20

    java面試的經驗11-20

    java面試的測試11-20

    主站蜘蛛池模板: 精品视频无码一区二区三区| 国产成人精品免费视频动漫| 国产综合精品女在线观看| 国产精品99久久不卡| 国产精品视频永久免费播放| 免费精品精品国产欧美在线欧美高清免费一级在线 | 国产精品青青在线观看爽香蕉 | 日韩一区二区三区精品| 亚洲午夜精品一区二区| 国产成人精品电影在线观看| 在线观看亚洲精品福利片| 国产精品小视频免费无限app| 国产精品久久久久无码av| 久久亚洲中文字幕精品有坂深雪 | 四虎国产精品永久地址49| 国产精品亚洲片在线| 亚洲精品美女久久久久99| 久久国产精品免费一区二区三区| 99久久99这里只有免费的精品| 亚洲国产另类久久久精品| 亚洲AⅤ永久无码精品AA| 精品久久久久久无码人妻蜜桃| 成人精品一区二区久久| 久久精品国产精品国产精品污| 97精品伊人久久大香线蕉app| 日韩欧精品无码视频无删节 | 欧美精品91欧美日韩操| 精品无码久久久久久久久久| 国产精品亚洲视频| 99精品影院| 99精品伊人久久久大香线蕉| 欧美777精品久久久久网| 国产精品免费网站| 国产精品嫩草影院久久| 国产精品你懂的| 少妇人妻偷人精品视频| 无码精品人妻一区二区三区影院| 久久精品成人| 欧美久久亚洲精品| 亚洲精品成人久久久| 亚洲欧美日韩久久精品第一区|