java對集合的面試題
Ⅰ java面試題及答案整理-Java集合list中裝了上百萬數據太耗內存,可以如何優化
在實際的Java編程中,List是我們經常使用的集合類型之一。面對大量數據存儲需求,正確優化內存使用至關重要。當List中裝入上百萬數據時,內存浪費問題凸顯。本文深度解析優化List內存使用方法,旨在避免資源浪費,提升程序性能。
首先,進行問題分析:List自動擴容機制在大量數據添加時頻繁觸發,每次擴容均需復制舊數據,導致內存消耗顯著。因此,了解內存使用情況,合理預估數據量,創建List時指定初始容量,可有效減少內存浪費。
解決方案包括以下四點:預估數據量、使用LinkedList、分批添加元素及運用Stream API。
預估數據量:提前預測List容量大小,創建時指定初始容量,避免頻繁擴容。
使用LinkedList:相比於ArrayList,LinkedList在添加或刪除元素時,無需復制數據,性能更優。
分批添加元素:將大容量數據分批添加,減少List擴容頻率,優化內存使用。
Stream API應用:利用Java 8引入的Stream API,減少創建新集合對象,避免內存浪費。
綜上,合理預估數據量、選擇合適的數據結構、分批添加元素及高效利用Stream API,是優化List內存使用的關鍵。在實際開發中,應綜合考量,靈活選擇優化策略,以實現更好的性能與更低的內存佔用。
Ⅱ java中HashMap和HashTable面試題問題,為什麼hashmap是屬於非同步的呢並且非同步的hashmap為什麼適合單線程
摘抄的,學到了
HashMap幾乎可以等價於Hashtable,除了HashMap是非synchronized的,並可以接受null(HashMap可以接受為null的鍵值(key)和值(value),而Hashtable則不行)。
HashMap是非synchronized,而Hashtable是synchronized,這意味著Hashtable是線程安全的,多個線程可以共享一個Hashtable;而如果沒有正確的同步的話,多個線程是不能共享HashMap的。Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的擴展性更好。
另一個區別是HashMap的迭代器(Iterator)是fail-fast迭代器,而Hashtable的enumerator迭代器不是fail-fast的。所以當有其它線程改變了HashMap的結構(增加或者移除元素),將會拋出,但迭代器本身的remove()方法移除元素則不會拋出異常。但這並不是一個一定發生的行為,要看JVM。這條同樣也是Enumeration和Iterator的區別。
由於Hashtable是線程安全的也是synchronized,所以在單線程環境下它比HashMap要慢。如果你不需要同步,只需要單一線程,那麼使用HashMap性能要好過Hashtable。
HashMap不能保證隨著時間的推移Map中的元素次序是不變的。
HashMap和Hashtable的比較是Java面試中的常見問題,用來考驗程序員是否能夠正確使用集合類以及是否可以隨機應變使用多種思路解決問題。HashMap的工作原理、ArrayList與Vector的比較以及這個問題是有關Java 集合框架的最經典的問題。Hashtable是個過時的集合類,存在於Java API中很久了。在Java 4中被重寫了,實現了Map介面,所以自此以後也成了Java集合框架中的一部分。Hashtable和HashMap在Java面試中相當容易被問到,甚至成為了集合框架面試題中最常被考的問題,所以在參加任何Java面試之前,都不要忘了准備這一題。
這篇文章中,我們不僅將會看到HashMap和Hashtable的區別,還將看到它們之間的相似之處。
HashMap和Hashtable的區別
HashMap和Hashtable都實現了Map介面,但決定用哪一個之前先要弄清楚它們之間的分別。主要的區別有:線程安全性,同步(synchronization),以及速度。
要注意的一些重要術語:
1) sychronized意味著在一次僅有一個線程能夠更改Hashtable。就是說任何線程要更新Hashtable時要首先獲得同步鎖,其它線程要等到同步鎖被釋放之後才能再次獲得同步鎖更新Hashtable。
2) Fail-safe和iterator迭代器相關。如果某個集合對象創建了Iterator或者ListIterator,然後其它的線程試圖「結構上」更改集合對象,將會拋出異常。但其它線程可以通過set()方法更改集合對象是允許的,因為這並沒有從「結構上」更改集合。但是假如已經從結構上進行了更改,再調用set()方法,將會拋出IllegalArgumentException異常。
3) 結構上的更改指的是刪除或者插入一個元素,這樣會影響到map的結構。
我們能否讓HashMap同步?
HashMap可以通過下面的語句進行同步:
Map m = Collections.synchronizeMap(hashMap);
結論
Hashtable和HashMap有幾個主要的不同:線程安全以及速度。僅在你需要完全的線程安全的時候使用Hashtable,而如果你使用Java 5或以上的話,請使用ConcurrentHashMap吧。
原文鏈接:Javarevisited翻譯:ImportNew.com-唐小娟
譯文鏈接:http://www.importnew.com/7010.html