Java 集合 ArrayList和HashMap的区别

来源:这里教程网 时间:2026-02-17 20:13:15 作者:

ArrayList和 HashMap 是 Java 中常用的两个集合类。尽管两者都是集合框架的一部分,但它们存储和处理数据的方式却完全不同。在这篇文章中,我们将看到这两个集合之间的主要区别。

Java 中的ArrayList与HashMap

1)实现:ArrayList实现List接口,而HashMap是Map接口的实现。List和Map是两个完全不同的集合接口。

2)内存消耗:ArrayList单独存储元素的值,并在内部维护每个元素的索引。

 ArrayList<String> arraylist = new ArrayList<String>();//String value is stored in array list arraylist.add("Test String");

HashMap存储键值对。对于每个值,必须在HashMap中关联一个键。这清楚地表明,与ArrayList相比,HashMap中的内存消耗很高。

HashMap<Integer, String> hmap= new HashMap<Integer, String>();//String value stored along with the key value in hash map hmap.put(123, "Test String");

3) 顺序 :ArrayList维护插入顺序,而HashMap则没有。这意味着ArrayList以与插入列表相同的顺序返回列表项。另一方面,HashMap不维护任何顺序,返回的键值对不按任何顺序排序。

4)重复:ArrayList允许重复元素,但HashMap不允许重复键(它允许重复值)。

5) 空值 :ArrayList可以包含任意数量的null元素。HashMap允许一个空键和任意数量的空值。

6) get方法:在ArrayList中我们可以通过指定它的索引得到元素。在HashMap中,通过指定相应的键来获取元素。

相关推荐