Java中的HashMap和ArrayList之间的区别?

Java中的HashMap和ArrayList之间的区别?,第1张

Java中的HashMap和ArrayList之间的区别?

您正在专门询问ArrayList和HashMap,但我认为要完全了解发生了什么,您必须了解Collections框架。因此,ArrayList实现List接口,而HashMap实现Map接口。因此,真正的问题是您何时要使用列表以及何时要使用地图。这是Java
API文档有很大帮助的地方。

清单:

有序集合(也称为序列)。该界面的用户可以精确控制列表中每个元素的插入位置。用户可以通过其整数索引(列表中的位置)访问元素,并在列表中搜索元素。

地图:

将键映射到值的对象。映射不能包含重复的键;每个键最多可以映射到一个值。

因此,正如其他答案所讨论的那样,列表接口(ArrayList)是使用索引访问的对象的有序集合,就像数组一样(就如ArrayList一样,顾名思义,它只是数组中的一个数组)。背景,但处理数组的许多细节已为您处理)。当您要按排序顺序(添加顺序,或者添加对象时指定的列表中的位置)时,可以使用ArrayList。

另一方面,Map接受一个对象,并将其用作另一个对象(值)的键(索引)。因此,假设您有具有唯一ID的对象,并且您知道将要在某个时候通过ID访问这些对象,Map将使您非常容易(并且更快/更高效)。HashMap实现使用键对象的哈希值来定位它的存储位置,因此不再保证值的顺序。但是,Java
API中还有其他类可以提供此功能,例如linkedHashMap,它还使用哈希表存储键/值对,还按添加键的顺序维护键的列表(linkedList),因此您始终可以按添加顺序再次访问这些项目(如果需要)。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5487794.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-12
下一篇2022-12-12

发表评论

登录后才能评论

评论列表(0条)

    保存