大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 Java學習 Java全面經典面試題及答案

Java全面經典面試題及答案

更新時間:2019-10-09 11:00:07 來源:動力節點 瀏覽2801次



  這里有10個經典的Java面試題,也為大家列出了答案。這是Java開發人員面試經常容易遇到的問題,相信你了解和掌握之后一定會有所提高。讓我們一起來看看吧。


timg (12).jpg


  1.Java的HashMap是如何工作的?


  HashMap是一個針對數據結構的鍵值,每個鍵都會有相應的值,關鍵是識別這樣的值。


  HashMap基于hashing原理,我們通過put()和get()方法儲存和獲取對象。當我們將鍵值對傳遞給put()方法時,它調用鍵對象的hashCode()方法來計算hashcode,讓后找到bucket位置來儲存值對象。當獲取對象時,通過鍵對象的equals()方法找到正確的鍵值對,然后返回值對象。HashMap使用LinkedList來解決碰撞問題,當發生碰撞了,對象將會儲存在LinkedList的下一個節點中。HashMap在每個LinkedList節點中儲存鍵值對對象。


  2.什么是快速失敗的故障安全迭代器?


  快速失敗的Java迭代器可能會引發ConcurrentModifcationException在底層集合迭代過程中被修改。故障安全作為發生在實例中的一個副本迭代是不會拋出任何異常的。快速失敗的故障安全范例定義了當遭遇故障時系統是如何反應的。例如,用于失敗的快速迭代器ArrayList和用于故障安全的迭代器ConcurrentHashMap。


  3.JavaBlockingQueue是什么?


  JavaBlockingQueue是一個并發集合util包的一部分。BlockingQueue隊列是一種支持操作,它等待元素變得可用時來檢索,同樣等待空間可用時來存儲元素。


  4.什么時候使用ConcurrentHashMap?


  在問題2中我們看到ConcurrentHashMap被作為故障安全迭代器的一個實例,它允許完整的并發檢索和更新。當有大量的并發更新時,ConcurrentHashMap此時可以被使用。這非常類似于Hashtable,但ConcurrentHashMap不鎖定整個表來提供并發,所以從這點上ConcurrentHashMap的性能似乎更好一些。所以當有大量更新時ConcurrentHashMap應該被使用。


  5.哪一個List實現了最快插入?


  LinkedList和ArrayList是另個不同變量列表的實現。ArrayList的優勢在于動態的增長數組,非常適合初始時總長度未知的情況下使用。LinkedList的優勢在于在中間位置插入和刪除操作,速度是最快的。


  LinkedList實現了List接口,允許null元素。此外LinkedList提供額外的get,remove,insert方法在LinkedList的首部或尾部。這些操作使LinkedList可被用作堆棧(stack),隊列(queue)或雙向隊列(deque)。


  ArrayList實現了可變大小的數組。它允許所有元素,包括null。每個ArrayList實例都有一個容量(Capacity),即用于存儲元素的數組的大小。這個容量可隨著不斷添加新元素而自動增加,但是增長算法并沒有定義。當需要插入大量元素時,在插入前可以調用ensureCapacity方法來增加ArrayList的容量以提高插入效率。


  6.Iterator和ListIterator的區別


  ●ListIterator有add()方法,可以向List中添加對象,而Iterator不能。


  ●ListIterator和Iterator都有hasNext()和next()方法,可以實現順序向后遍歷,但是ListIterator有hasPrevious()和previous()方法,可以實現逆向(順序向前)遍歷。Iterator就不可以。


  ●ListIterator可以定位當前的索引位置,nextIndex()和previousIndex()可以實現。Iterator沒有此功能。


  ●都可實現刪除對象,但是ListIterator可以實現對象的修改,set()方法可以實現。Iierator僅能遍歷,不能修改。


  7.什么是CopyOnWriteArrayList,它與ArrayList有何不同?


  CopyOnWriteArrayList是ArrayList的一個線程安全的變體,其中所有可變操作(add、set等等)都是通過對底層數組進行一次新的復制來實現的。相比較于ArrayList它的寫操作要慢一些,因為它需要實例的快照。


  CopyOnWriteArrayList中寫操作需要大面積復制數組,所以性能肯定很差,但是讀操作因為操作的對象和寫操作不是同一個對象,讀之間也不需要加鎖,讀和寫之間的同步處理只是在寫完后通過一個簡單的"="將引用指向新的數組對象上來,這個幾乎不需要時間,這樣讀操作就很快很安全,適合在多線程里使用,絕對不會發生ConcurrentModificationException,因此CopyOnWriteArrayList適合使用在讀操作遠遠大于寫操作的場景里,比如緩存。


  8.迭代器和枚舉之間的區別


  如果面試官問這個問題,那么他的意圖一定是讓你區分Iterator不同于Enumeration的兩個方面:


  ●Iterator允許移除從底層集合的元素。


  ●Iterator的方法名是標準化的。


  9.Hashmap如何同步?


  當我們需要一個同步的HashMap時,有兩種選擇:


  ●使用Collections.synchronizedMap(..)來同步HashMap。


  ●使用ConcurrentHashMap的


  這兩個選項之間的首選是使用ConcurrentHashMap,這是因為我們不需要鎖定整個對象,以及通過ConcurrentHashMap分區地圖來獲得鎖。


  10.IdentityHashMap和HashMap的區別


  IdentityHashMap是Map接口的實現。不同于HashMap的,這里采用參考平等。


  ●在HashMap中如果兩個元素是相等的,則key1.equals(key2)


  ●在IdentityHashMap中如果兩個元素是相等的,則key1==key2


以上就是動力節點java培訓機構小編分享的“Java全面經典面試題及答案”的內容,希望對大家有幫助,更多java面試題請繼續關注動力節點java培訓機構官網,每天會精彩內容分享與你。


相關java面試題推薦


2019最新最全java面試題及答案:http://www.dabaquan.cn/tutorial_baseinterviewquestions/


Java常見面試題匯總:http://www.dabaquan.cn/javazixun/1007.html


2019最新java面試題含答案(基礎篇):http://www.dabaquan.cn/javazixun/1145.html


各大互聯網公司Java面試題匯總:http://www.dabaquan.cn/javazixun/1867.html


2019最新Java常見面試題(附帶答案):http://www.dabaquan.cn/javazixun/891.html


常被問到的Java面試題(帶全部答案):http://www.dabaquan.cn/javazixun/886.html


提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 国产精品中文 | 成人毛片在线播放 | 青青青青手机在线视频观看国产 | 99久久香蕉 | 波多野结衣久久一区二区 | 亚洲国产精品视频 | 高清国产美女一级毛片 | 自拍偷拍三级 | 中文一区二区视频 | 私人影院在线 | 一级片按摩 | 男人天堂黄色 | 老司机久久影院 | 真人女人一级毛片免费视频观看 | 午夜宅男免费完整在线观看 | 日韩视频 中文字幕 | 一级特黄a视频 | 亚洲一区二区三区福利在线 | 欧美一级毛片国产一级毛片 | 一级毛片高清免费播放 | 九九影视理论片在线播放 | 免费高清在线爱做视频 | 国产成人一区二区三中文 | 一级毛片在线观看免费 | a毛片在线观看 | 国产一区视频在线 | 亚洲香蕉毛片久久网站老妇人 | 免费观看一级欧美大 | 老司机午夜视频在线观看 | 中文字幕不卡在线观看 | 奇米网狠狠网 | 五月激情五月婷婷 | 波多野结衣一区二区三区 | 久草视频免费在线看 | 国产高清福利91成人 | 亚洲精品综合一区二区三区在线 | 国产无套乱子伦精彩是白视频 | 婷婷综合亚洲 | 在线成人欧美 | 亚洲视频二 | 影音先锋久草 |