创建集合的方式和创建对象是一样的 :
创建对象 : 类名 对象引用名 = new 类名 ();
创建集合 : 接口类名 集合引用名 = new 实现类名 () ;
给集合加上泛型 , 该集合就只能存储泛型中指定的类别的对象了.
如果不加泛型 , 默认是Object类泛型 , 什么类别都能存储 , 用的时候必须要先查看该元素的类型, 就像同时往杯中倒了咖啡啤酒洗衣粉 , 喝起来可就难受了 , 还要费力把它们挑出来.
接口 < 这里写泛型类 > 引用名 = new 实现类 <>();
collection 接口有两个子接口 List 和 set
List 的 常用实现类有 : ArrayList(数组实现) 和 LinkedList(链表实现)
List 的特点是有放入顺序 , 有下标 , 元素可重复,可以更改指定位置元素
ArrayList 的特点 : 操作速度快 , 查询速度快 , 增删速度慢 , 线程不安全
LinkedList : 操作速度快 , 查询慢 , 增删快 , 线程不安全
创建集合的写法:
假如是要一个Student类型的集合:
List <Student> list = new ArrayList <> (); 或者
List <Student> list = new LinkedList <> ();
常用方法:增删改查 ( index为下标固定是 int 类型 , E为类型泛型 e指代元素
list . add( index , (E) e); 添加元素 e 到 下标 index 位置
list . get ( index); 查找下标为 index 的元素
set( index , (E) e); 更换index的元素为e
remove( index); 删除index的元素
遍历方式 for i 遍历 和forEach遍历
for i 即数组遍历, 这里写一下forEach
for( Student stu : list ){ //创建时泛型写的什么 , 这里冒号左边就创建一个该类引用,右边是集合名
//这个遍历的方式是每一次循环 , 都会新建一个引用,指向集合中的一个元素 , 所以可以用这个引用名来调用该元素的属性和方法
}
set 接口的常用实现类是 HashSet 和 LinkedHashSet
HashSet 的特点是无放入顺序 , 无下标 , 元素不可重复 , 无法更改指定位置,操作速度快 , 线程不安全 , 查询速度比LinkedList快 , 增删速度比ArrayList快 .
LinkedHashSet 比HashSet多了一个记录,用于维护元素的写入顺序,但是内部存储依然与HashSet相同
hashCode : Object中的方法 , 将一个对象的内容返回为一段 int 类型的哈希码
set 的实现类的无序是指不维护存入顺序 , 其内部是使用哈希码和equals方法 来决定存储顺序的
创建方式 : ( E 表示泛型 )
Set <E> set = new HashSet <>();
Set <E> set = new LinkedHashSet <>();
常用方法 : 增删查
因为元素不重复 , 又没有下标 , 所以没有直接更改元素的方法, 可以先删再放来代替更改
增: add( (E) e);
删: remov((E) e);
查: get( (E) e);
只能使用forEach遍历