Java集合类
Q1:为什么需要Java集合类
弥补数组的缺陷,数组的长度不可变,而集合类的长度可变。
数组只能存储相同类型的元素,而集合类可以存储不同类型的元素。
数组可以存储基本类型和引用类型,而集合类只能存储引用类型。
Q2:为什么集合类的种类如此多?
当然是为了满足不同需求,就像一个班的学生姓名可以相同,但是学号不能相同,所以这就需要我们在众多的集合类中选取合适的集合去使用。
新学的方法一:
boolean retainAll( ):判断两个集合是否有交集
假设有A,B两个集合,A对B做交集,最终的结果保存在A中,B不变。返回值表示的是A是否发生过改变。
Collection A =new ArrayList();
Collection B =new ArrayList();
A.add(1);
A.add(2);
A.add(3);
B.add(1);
B.add(2);
B.add(3);
System.out.println(A.retainAll(B));
System.out.println(A);
输出结果:
false//因为A中的元素未发生改变
[1, 2, 3]//两个集合的交集元素存入A中
方法二:
T[ ] toArray(T[ ] a):将集合转换为数组,可以实现集合的遍历
其实,这段程序主要学到的是向上转型与向下转型
Collection A =new ArrayList();
A.add("ddd");//Object obj="hello";向上转型
A.add("fffff");
A.add("qqq");
//转换为数组
Object obj[]=A.toArray();
//读取数组的元素
for(int i=0;i<obj.length;i++) {
System.out.println(obj[i]);
String s=(String)obj[i];//向下转型
System.out.println(s.length());
}
输出结果:
ddd
3
fffff
5
qqq
3
方法三:
Iterator iterator()//集合的遍历,有了方法三,遍历集合时方法二可以不去考虑了
接口 Iterator方法:
boolean hasNext()
如果仍有元素可以迭代,则返回 true。
E next()
返回迭代的下一个元素。
//创建集合对象
Collection c=new ArrayList();
//创建学生对象
Student s1=new Student("d",1);
Student s2=new Student("e",2);
Student s3=new Student("t",3);
//添加集合元素
c.add(s1);
c.add(s2);
c.add(s3);
//创建迭代器
Iterator it=c.iterator();
//遍历集合
while(it.hasNext()){
Student s=(Student)it.next();//向下转型
System.out.println(s.getName()+"---"+s.getAge());
}