黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學(xué)習(xí)攻略 2020經(jīng)典Java面試題集

2020經(jīng)典Java面試題集

更新時間:2019-12-23 11:08:32 來源:動力節(jié)點 瀏覽4593次

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

2020經(jīng)典Java面試題集

  Java的HashMap是如何工作的?

  HashMap是一個針對數(shù)據(jù)結(jié)構(gòu)的鍵值,每個鍵都會有相應(yīng)的值,關(guān)鍵是識別這樣的值。

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

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

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

  Java BlockingQueue是什么?

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

  什么時候使用ConcurrentHashMap?

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

  哪一個List實現(xiàn)了最快插入?

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

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

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

  Iterator和ListIterator的區(qū)別

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

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

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

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

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

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

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

  迭代器和枚舉之間的區(qū)別

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

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

  ●Iterator的方法名是標(biāo)準(zhǔn)化的。

  Hashmap如何同步?

  當(dāng)我們需要一個同步的HashMap時,有兩種選擇:

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

  ●使用ConcurrentHashMap的

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

  IdentityHashMap和HashMap的區(qū)別

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

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

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

2020經(jīng)典Java面試題集

      以上就是動力節(jié)點Java培訓(xùn)機構(gòu)小編介紹的“2020經(jīng)典Java面試題集”的內(nèi)容,希望對大家有幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。

相關(guān)推薦

最新最全java面試題及答案(初級到高級)

史上最全的中高級JAVA工程師面試題及答案匯總

Java高級開發(fā)工程師面試題

2019史上最全java面試題題庫大全800題

哪有資深java工程師面試題

提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 中文亚洲日韩欧美 | 国产精品23p | 九九成人免费视频 | 91精品一区二区三区在线 | 美女高清特黄a大片 | 多人伦交性欧美精品欧 | 拔擦拔擦8x华人免费久久 | 日韩在线小视频 | 成人av手机在线观看 | 欧美在线黄色 | 一道本在线播放 | 午夜寂寞影视 | 日本大片久久久高清免费看 | 手机看片一区 | 日本免费一区二区视频 | 免费人成网站 | 波多野一区二区三区在线 | 日本三级香港三级人妇99 | 涩涩色中文综合亚洲 | 嗯啊视频在线 | 曰批全过程免费视频观看软件 | 抖音成人短视频 | 日韩中文字幕在线观看视频 | 日韩黄色影视 | 中文字幕日韩精品在线 | 老司机69精品成免费视频 | 欧美成人激情视频 | 亚洲欧美四级在线播放 | 国产日韩欧美久久久 | 正在播放国产尾随丝袜美女 | 黄色香蕉网 | 毛片在线播放视频 | 免费在线一级毛片 | 欧美性受xxxx喷水性欧洲 | 中国美女挠脚心丝袜vk | 日韩亚洲一区中文字幕 | 免费看黄视频网站 | 亚洲一二三在线 | 成人3p视频免费 | 久久9精品 | 麻豆国产成人精品午夜视频 |