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中文网其他相关文章!