集合类的特点:提供了一种存储空间可变的存储模型,存储的数据容量可以随时发生改变。
集合类体系结构:集合分为单列集合Collection和双列集合Map。
单列集合Collection分为可重复的List和不可重复的Set。
Collection集合概述
- 是单列集合的顶层接口,它表示一组对象,这些对象也称为Collection的元素。
- JDK不提供此接口的任何直接实现,它提供更具体的子接口实现(如List和Set)。
案例:Collection集合存储学生对象并遍历
需求:创建一个存储学生对象的集合,存储三个学生对象,使用程序实现在控制台遍历该集合。
思路:
- 定义学生类。
- 创建Collection集合对象。
- 创建学生对象。
- 把学生添加到集合。
- 遍历集合(迭代器实现)。
package test2;
public class Student {
private String name;
private int age;
public Student(){
}
public Student(String name,int age){
this.name=name;
this.age=age;
}
public void setName(String name){
this.name=name;
}
public void setAge(int age){
this.age=age;
}
public String getName(){
return name;
}
public int getAge(){
return age;
}
}
package test2;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
public class CollectionDemo {
public static void main(String[] args){
Collection<Student> c=new ArrayList<>();
Student s1=new Student("周杰伦",42);
Student s2=new Student("王俊凯",23);
Student s3=new Student();
s3.setName("吕九洋");
s3.setAge(22);
c.add(s1);
c.add(s2);
c.add(s3);
//遍历集合使用迭代器
Iterator<Student> it=c.iterator();
while(it.hasNext()){
Student s=it.next();
System.out.println(s.getName()+" "+s.getAge());
}
}
}
List集合概述和特点
List集合概述
- 有序集合(也称为序列),用户可以精确控制列表中每个元素的插入位置。用户可以通过整数索引访问元素,并搜索列表中的元素。
- 与Set集合不同,List通常允许重复的元素。
List集合的特点
- 有序:存储和取出的元素顺序一致。
- 可重复:存储的元素可以重复。
package test2;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class ListDemo {
public static void main(String[] args) {
List<Student> list=new ArrayList<>();
Student s1=new Student("王俊凯",23);
Student s2=new Student("海贼王",34);
list.add(s1);
list.add(s2);
Iterator<Student> it=list.iterator();
while(it.hasNext()){
Student s=it.next();
System.out.println(s.getName()+" "+s.getAge());
}
for(int i=0;i<list.size();i++){
Student s=list.get(i);
System.out.println(s.getName()+" "+s.getAge());
}
for(Student s:list){
System.out.println(s.getName()+s.getAge());
}
}
}
列表迭代器ListIterator
作为了解,一般集合的迭代器就够用了。