集合大总结

一、Iterable, Collection,list,Set, Map 都是接口

其余都是实现类

二、四个接口

1.collection

是List和Set接口的父接口 List中的方法很多继承于collection

常用方法:增add ,删 remove ,查 get() 获得集合数据的个数size()。

判断是否含有contains()是否相等 equals();

2.List

接口存储一组允许重复,有序(插入顺序)的对象,有下标,插入顺序作为遍历的顺序

3.Set

接口存储一组唯一,无序的对象没下标插入的顺序跟遍历的顺序是不一样的Set接口中没有自有方法,全部继承自Collection接口

4.Map

map中存储是一存储两个值,键(key)和值(Value)合起来叫键值对(entry)map中键和值都可以为任何值(包括Null和集合),但键不可以重复,值可以重复。

不是collection子接口,有独有的方法;

增put(key value) 删 remove(key) 获取get(key)

KeySet()把集合中的key提取到另一个集合中;

Values() 获得集合中的值。

九个类

List   包括Vector  LinkedList   ArryList

Set   包括 HashSet  LinkedHashSet   TreeSet

Map  包括 HashMap  LinkedHashMap TreeMap

Vector

LinkedList

ArryList

HashSet

LinkedHashSet

TreeSet

HashMap

LinkedHashMap

TreeMap

线程安全

优缺点

增删慢

查找慢增删快

查找慢增删慢查找快

增删查找速度都不错

但没有下标增删查找速度都不错

但没有下标增删查找速度都不错

但没有下标增删查找速度都不错

但没有下标增删查找速度都不错

但没有下标增删查找速度都不错

但没有下标

数据结构

数组

链表

数组

Hash表

Hash表

平衡二叉树

Hash表

Hash表

平衡二叉树

注释:LinkedHashSet和HashSet的区别在于遍历顺序是否和插入顺序一致

泛型

在集合中对集合进行存储数据时很方便,但是取出来的时候不方便,为了便于存取,对可以对集合进行限制,就是让集合可以存储任意类型的数据,但只能存储一种,这种限制的方式就是泛型

例如:

LinkedList Ls=new LinkedList<>(): 即这个集合中只能存储String类型的数据,当使用常用数据类型时 要注意泛型是他们的包装类

迭代器

对存在集合中的数据进行遍历的时候长用到迭代器,迭代器既可以遍历有下标的集合,也可遍历没有下标的结合。迭代器的常规写法

For(遍历的数据的类型 存储数据:遍历的数据)

列如定义了一个HashSet集合,HashSetHs=new HashSet<>()

遍历时for(String s:Hs){}

当遍历Map集合时,需要注意写法

例如遍历一个学籍管理集合

HashMap HS=new HashMap<>();时

for(Entry < Integer ,student >)e:Hs.entrySet()){}

比较器

用于自定义类之间的比较排序

具体代码例子

Public class com1 implement Comparetor {

Public int (student s1 ,student s2)

//先比名字后比年龄

Int co =s1.getName().comparTo(s2.getName)//compareTo 返回的是一个int值根据int值得大小判断排序

If(co==0)//当两值相等的时候,在进行年龄的比较排序

{

Return s1.getAge()-s2.getAge;

}

Else return co;

}

先比成绩再对名字进行排序

Public class com2  implement Comparetor {

Public int (student s1 ,student s2)

//先比名字后比年龄

Int co =s1.getName().comparTo(s2.getName)//compareTo 返回的是一个int值根据int值得大小判断排序

If(s1.getAge()-s2.getAge==0)//当两值相等的时候,在进行年龄的比较排序

{

Return s1.getName().comparTo(s2.getName);

}

Else {

return s1.getAge()-s2.getAge

}

}


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,906评论 18 399
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 5,386评论 0 3
  • Java集合框架结构图完整版 在完整版的结构图中Collection集合和Map下有许多未实现的抽象类(Ab...
    LizGbus8阅读 4,342评论 0 3
  • importUIKit classViewController:UITabBarController{ enumD...
    明哥_Young阅读 9,427评论 1 10
  • 一波未平,一波又起 …… 12亿刚刚被冻结,法院再次出手,冻结贾跃亭99%的股份。 招商银行,打响第一枪 …… 昔...
    黑鸿升阅读 5,054评论 2 3