一.集合
1.集合框架概述
①集合和数组
集合和数组都是对多个数据进行存储的
存储在内存层面
②数组的特点
优点:
初始化后长度不变
指明了数组的元素类型(即定义好后,元素的类型也确定)
缺点:
初始化后,长度不可更改
数组中提供的方法非常有限(缺乏增删改查的操作)
数组实际的元素也不可知
有序可重复,而无需不可重复需求无法解决
③java集合能够满足数组的特点即两种体系
Colletion和Map两种体系
Colletion:List接口和Set接口(单列集合)
List接口:存储有序可重复 动态数组{ArrayList,Linklist,Vector}
Set接口:存储无序不可重复 高中集合的概念{HashSet,Linked,TreeSet}
Map接口:HashMap,LinkedMap(双列集合即key-value)
2.Colletion接口中的方法使用
①方法一
Collection a = new ArrayList();
a.add("123");a.add("abc");a.add(new Date());//a.addAll(Colletion b)
a.size();
a.isEmpty();
a.clear();
a.contains("123");//a.containsAll(Colletion t)
//contains是如何计算两个类相同的
//a.contains("123")则是调用了String类的equals方法,然后来对比类中对象属性是否相同
//a.contains(new Person())若判断是否包含自定义类,不重写equals方法,则默认判断==即地址,若重写equals,可判断对象属性
//即自定义类需要重写equals方法来满足contains的需求
a.remove("123");//移除元素也用equals来判断
//例子关于重写不重写equals
a.add(new dog(12));
System.out.println(a.remove(new dog(12)));//false因为此时比较的==即地址
System.out.println(a.remove(new dog(12)));//true 因为重写了equals方法然后判断属性
//a.removeAll(Collection b);
//a.retainAll(Collection b);移除与b交集的所有元素
//a.equals(Collection b);判断ab是否相等即元素是否都相等,注意此时是有序
//a.hashCode()返回当前对象的哈希值
class dog{
public int age;
dog(int age){
this.age=age;
}
@Override
public boolean equals(Object obj) {
dog o = (dog)obj;
return this.age==o.age;
}
}
②方法2
Collection a = new ArrayList();
a.add("123");a.add("abc");
//集合转化为数组
//Object[] arr = a.toArray();
//数组转化为集合
//ArrayList array= Arrays.asList();
//可以理解Iter为指针,指向集合的0号元素,每次next都会到下一个元素访问
Iterator Iter = a.iterator();
while(Iter.hasNext()){
System.out.println(Iter.next());//输出集合中的全部元素
}
//错误写法
//会导致各一个元素输出一个,且会导致异常(指针所在位置无元素)
while(Iter.next()!=null){
System.out.println(Iter.next());
}
//错误写法
//会导致哟永远输出123 即因为每次调用iterator都会新生成一个指针
while(a.iterator().hasNext()){
System.out.println(a.iterator().next());
}
//注意iter.remove()可以删除当前指针指向的元素
//加强for循环
//也可以循环得到集合a的元素,a底层也调用了迭代器,即每一次都会把得到的对象赋值给obj
for(Object obj:a){
System.out.println(a);