博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java集合杂谈
阅读量:4970 次
发布时间:2019-06-12

本文共 1495 字,大约阅读时间需要 4 分钟。

  在Java中有普通集合、同步(线程安全的集合)、并发集合。普通集合通常性能最高,但是不保证多线程的安全性和并发的可靠性。线程安全集合仅仅是给集合添加了synchronized同步锁,严重牺牲了性能,而且对并发的效率就更低了,并发集合则通过复杂的策略不仅保证了多线程的安全而且又提高了并发时的效率。

  并发集合常见的有ConcurrentHashMap、ConcurrentLinkedQueue、ConcurrentLinkedDeque等。并发集合位于java.util.concurrent包下,时JDK1.5之后才有的。

  Collections工具类提供了相关的API,可以让ArrayList、HashSet、HashMap不安全的集合变为安全的。

  List的三个子类的特点

实现类 底层结构 线程安全 查询速度 增加删除速度
ArrayList 数组
LinkedList 链表
voctor 数组

  List和Set、Map的区别

    结构方面:

      List和Set是存储单列数据的集合,Map是存储键值对这样的双列数据的集合;List中存储的数据是有顺序,并且允许重复。Set中存储的数据是无序的,且不允许有重复,但元素在集合中的位置由元素的hashcode决定,位置是固定的(Set集合是根据hashcode来进行数据的存储,所以位置是固定的,但是位置不是用户可以控制的,所以对于用户来说Set中的元素还是无序的)。Map中存储的数据是没有顺序的,其键(Key)不能重复,值(Value)可以有重复。

    实现类:

      List接口有三个实现类(ArrayList:基于数组实现,非线程安全的,效率高,便于索引,但不便于插入删除;LinkedList:基于链表实现,链表内存是散乱的,每一个元素存储本身内存地址的同时还要存储下一个元素的地址。链表增加和删除快,查找慢;Vector:基于数组实现,线程安全的,效率低)。

      Set接口有两个实现类(HashSet:底层是由HashMap实现,不允许集合中有重复的值,使用该方式时需要重写equals()和hashCode()方法;LinkedHashSet:继承于HashSet,同时又基于LinkedHashMap来进行实现,底层使用的是LinkedHashMap)。

      Map接口有三个实现类(HashMap:基于hash表的Map接口实现,非线程安全,高效,支持null值和null键;HashTable:线程安全,低效,不支持null值和null键;LinkedHashMap:是HashMap的一个子类,保存了记录的插入顺序;SortMap接口:TreeMap,能够把它保存的记录根据键排序,默认是键值的升序排序)。

    区别:

      List集合中对象按照索引位置排序,可以有重复对象,允许按照对象在集合中的索引位置检索对象,例如通过list.get(i)方法来获取集合中的元素;Set集合中的对象不按照特定的方式排序,并且没有重复对象,但它的实现类能对集合中的对象按照特定的方式排序,例如TreeSet类,可以按照默认顺序,也可以通过实现Java.util.Comparator<Type>接口来自定义排序方式;Map中的每一个元素包含一个键和一个值,成对出现,键对象不可以重复,值对象可以重复。

 

转载于:https://www.cnblogs.com/fanqisoft/p/10816440.html

你可能感兴趣的文章
java小技巧
查看>>
POJ 3204 Ikki's Story I - Road Reconstruction
查看>>
【BZOJ】2959: 长跑(lct+缩点)(暂时弃坑)
查看>>
iOS 加载图片选择imageNamed 方法还是 imageWithContentsOfFile?
查看>>
toad for oracle中文显示乱码
查看>>
SQL中Group By的使用
查看>>
错误org/aopalliance/intercept/MethodInterceptor解决方法
查看>>
两个表格中数据不用是一一对应关系--来筛选不同数据,或者相同数据
查看>>
Strict Standards: Only variables should be passed by reference
查看>>
hiho_offer收割18_题解报告_差第四题
查看>>
AngularJs表单验证
查看>>
静态方法是否属于线程安全
查看>>
02号团队-团队任务3:每日立会(2018-12-05)
查看>>
SQLite移植手记1
查看>>
js05-DOM对象二
查看>>
mariadb BINLOG_FORMAT = STATEMENT 异常
查看>>
C3P0 WARN: Establishing SSL connection without server's identity verification is not recommended
查看>>
iPhone在日本最牛,在中国输得最慘
查看>>
动态方法决议 和 消息转发
查看>>
js 基础拓展
查看>>