List集合、Set集合、Map集合

List:1、是线性,有顺序的
2、可以放重复的值
3,元素有下标
ArrayList :实现了List接口,底层利用数组,在增删改时效率较低 (原因是数组在存储 的时候是一块连续的存储单元, 在增删时要对元素进行移动),在查询的时候效率高(原因是利用下标输出)。
LinkedList:实现了List接口,底层利用链表,在增删改时效率较高(原因是),在查询的时候效率低,需要遍历查找
Vector :底层用数组实现List接口的另一个类. 线程安全,消耗资源,效率最低.

Set: 无序的,不可以存放重复的值,没有下标,无法通过下标获取对象。可以用加强for循环和 Iterable接口中的iterator()方法(原因是Set是Collection集合的子类,而Collection集合实现了Iterable接口)。

    Iterator<People> its=sets.iterator();
      while(its.hasNext()){
        People p=its.next();
        System.out.println(p);
     } 

HashSet: 判断重复用hashcode和equals 方法判断是否重复
TreeSet:和HashSet一样,可以进行排序(实现了Comparable接口)

Arrays.sort() 等可以排序是因为实现了comparable接口。

排序的接口:Comparable和 Comparator(挽救比较器)。 Comparable接口里有方法compareTo(Object o);Comparator接口里有方法compare(Object o1,Object o2);

Map:集合的一种形式,存储方式key_value键值队方式
key:不要求有序,不允许重复
value:不要求有序,允许重复
Map的底层实现是利用:数组+链表结构

HashMap: key和value 允许一个为null
HashTable: key和value 任一一个都不允许为null
TreeMap : 可以排序按键升序 实现了Comparator接口

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值