java map(为什么java中声明多用Map,List而不是具体实现类型)
本文目录
- 为什么java中声明多用Map,List而不是具体实现类型
- 今天看项目,看到别人在java中使用pair,这和map有啥区别呢
- java中map和list的区别
- JAVA中几种集合(List、Set和Map)的区别
- java中map与set的区别是什么
为什么java中声明多用Map,List而不是具体实现类型
设计模式应该是 适配器 模式吧。
至于为什么用Map实现,个人理解,是为了利用Map的Key不能重复, 来实现 Set的值不重复。
可以看到HashSet的add方法利用的HashMap的put方法,只不过是把值当做了 HashMap中的Key
而put的Value直接定义了一个空对象
今天看项目,看到别人在java中使用pair,这和map有啥区别呢
pair顾名思义 配对。就像你的身份证和代表你本人一样。k v结构,与map类似。不过map的语意,代表了key只是访问value的索引,实际key意义不大。且不能通过value 索引key.而pair不是,它强调的是key 跟value的唯一映射,数据结构上抽象成letf right,可以互相索引。这就意味着k v都是存在实际意义。一般使用场景,比如游戏场景,有充值点卡。那么生成卡号和卡密就可以放在pair中,好像还有一个Thrip还是啥,提供三个值映射的数据结构,它是pair的升级版本,有left middle right。可以看看,另外guava的BiMap也提供了类似的操作,通过reverse可以控制反转数据,由value也能获取到key。
java中map和list的区别
1、Java中的集合包括三大类,它们是Set、List和Map,它们都处于java.util包中,Set、List和Map都是接口,它们有各自的实现类。Set的实现类主要有HashSet和TreeSet,List的实现类主要有ArrayList,Map的实现类主要有HashMap和TreeMap。
2、List中的对象按照索引位置排序,可以有重复对象,允许按照对象在集合中的索引位置检索对象,如通过list.get(i)方式来获得List集合中的元素。List是有序的Collection,使用此接口能够精确的控制每个元素插入的位置。用户能够使用索引(元素在List中的位置,类似于数组下标)来访问List中的元素,这类似于Java的数组。List允许有相同的元素。实现List接口的常用类有LinkedList,ArrayList,Vector和Stack。
3、Map中的每一个元素包含一个键对象和值对象,它们成对出现。键对象不能重复,值对象可以重复。Map提供key到value的映射。一个Map中不能包含相同的key,每个key只能映射一个value。Map接口提供3种集合的视图,Map的内容可以被当作一组key集合,一组value集合,或者一组key-value映射。
JAVA中几种集合(List、Set和Map)的区别
Java中的集合包括三大类,它们是Set、List和Map。它们都处于
java.util
包中,Set、List和Map都是接口。Set中的对象不按特定方式排序,并且没有重复对象。但它的有些实现类能对集合中的对象按特定方式排序,例如TreeSet类,它可以按照默认排序,也可以通过实现java.util.Comparator
接口来自定义排序方式。List中的对象按照索引位置排序,可以有重复对象,允许按照对象在集合中的索引位置检索对象,如通过list.get(i)方式来获得List集合中的元素。Map中的每一个元素包含一个键对象和值对象,它们成对出现。键对象不能重复,值对象可以重复。Map的功能方法 : 方法put(Object key, Object value)添加一个“值”(想要得东西)和与“值”相关联的“键”(key)(使用它来查找)。方法get(Object key)返回与给定“键”相关联的“值”。可以用containsKey()和containsValue()测试Map中是否包含某个“键”或“值”。标准的Java类库中包含了几种不同的Map:HashMap, TreeMap, LinkedHashMap, WeakHashMap, IdentityHashMap。它们都有同样的基本接口Map,但是行为、效率、排序策略、保存对象的生命周期和判定“键”等价的策略等各不相同。执行效率是Map的一个大问题。看看get()要做哪些事,就会明白为什么在ArrayList中搜索“键”是相当慢的。而这正是HashMap提高速度的地方。HashMap使用了特殊的值,称为“散列码”(hash code),来取代对键的缓慢搜索。“散列码”是“相对唯一”用以代表对象的int值,它是通过将该对象的某些信息进行转换而生成的。所有Java对象都能产生散列码,因为hashCode()是定义在基类Object中的方法。java中map与set的区别是什么
Map与Set的本质区别有:Set不能包含重复的元素,最多有一个空值,继承自Collection接口,底层是Map实现机制。Map不能包含重复的键,每个键最多对应一个映射的值,不能有空值键。两接口提供的方法不完全一样。
更多文章:
电子墨水屏阅读器(电子墨水屏的电子阅读器,可以连接手机充当手机的第二块屏幕吗)
2023年2月8日 10:15
轰天炮投影仪哪个型号比较好(轰天炮投影仪m20和y5哪款好呢)
2023年2月28日 23:15
坚果pro2(锤子坚果pro2充电标志一下暗一下亮怎么回事)
2024年8月22日 14:20
荣耀6 plus 怎么样(华为荣耀6plus怎么样好不好 荣耀6plus配置参数一览)
2023年7月13日 01:00
测试显卡显存损坏的软件(显卡的显存如何检测,用什么软件比较好)
2024年9月2日 05:55
华为p40和mate30哪个好一点(华为p40和mate30选哪个好)
2024年5月28日 15:31
三星手机22年新款(三星 Galaxy S22 系列参数曝光,将于22年1月份发布)
2024年6月11日 08:17
诺基亚5300是什么在中国卖的(怎么查询诺基亚5300手机具体是哪个国家生产的)
2024年6月12日 08:35