Hash Map 擷取順序是否保留?
在 Java 中,HashMap 採用特定的演算法來儲存和檢索數據,這讓一些用戶感到疑惑檢索值的順序。當我們深入研究程式碼片段時,我們將揭開 HashMap 檢索順序背後的真相。
import java.util.HashMap; public class HashMapExample { public static void main(String[] args) { HashMap<Integer, String> hashmap = new HashMap<Integer, String>(); hashmap.put(1, "apple" ); hashmap.put(2, "lemon" ); hashmap.put(3, "orange" ); hashmap.put(4, "banana" ); hashmap.put(5, "litchi" ); hashmap.put(6, "mango" ); hashmap.put(7, "papaya" ); System.out.println(hashmap.size()); for (String key : hashmap.values()) { System.out.println(key); } } }
輸出:
7 apple lemon orange banana litchi mango papaya
令人驚訝的行為:
令人驚訝的是,這些值是在它們插入的順序相同。然而,這個觀察可能並不總是成立。
真相:
根據 HashMap Javadoc,不能保證檢索順序隨著時間的推移保持一致。這意味著檢索順序可以任意更改。
需要一致的排序嗎?
如果一致的排序至關重要,可以選擇其他資料結構,例如LinkedHashMap 或TreeMap .
以上是Java的HashMap保證檢索順序嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!