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不能包含重复的键,每个键最多对应一个映射的值,不能有空值键。两接口提供的方法不完全一样。
更多文章:
索尼xperia1ii音质(索尼xperia1ii港版和国行版有什么区别-区别对比)
2024年4月30日 02:12
华为手机特价599(华为手机出现talkback,这是怎么回事)
2024年10月4日 01:25
华为mate30价格官网4g(华为mate30,6+128版本怎么样)
2024年7月19日 10:08
红米k20pro游戏变声(红米k30ultra打游戏为啥会变声)
2024年9月27日 02:10
三星note10价格预估(手机信号升级5G后,原来的4G手机怎么办)
2024年5月22日 08:50
什么是cdma手机(什么是CDMA手机啊买它有什么优点和缺点呢哪位能详细点告诉我)
2024年5月15日 01:51
荣耀20青春版参数配置处理器(荣耀20青春版参数配置怎么样)
2023年11月5日 02:05
手机爆炸事件(河南一三星手机爆炸,男子背包瞬间起火,三星手机为啥又爆炸)
2023年11月23日 13:45