Set集合使用的有两个类HashSet,TreeSet
HashSet实现set接口,它不保证Set的迭代顺序,特别是它不保证该顺序恒久不变,允许null。
TreeSet,不紧实现set进口,也可以在遍历集合时按照自然顺序递增排序,也可以按照指定比较器递增顺序
package com.java.charpter14;
import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;
public class UpdateStu implements Comparable<Object>{
String name;
long id;
public UpdateStu(String name,long id)
{
this.name=name;
this.id=id;
}
@Override
public int compareTo(Object o) {
// TODO Auto-generated method stub
UpdateStu kj=(UpdateStu)o;
int result=id>kj.id?1:(id==kj.id?0:-1);
return result;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
/******省略了属性setXX和getXX的方法
*
*/
public static void main(String[] args) {
UpdateStu s1=new UpdateStu("李同学", 01011);
UpdateStu s2=new UpdateStu("陈同学", 01021);
UpdateStu s3=new UpdateStu("王同学", 01051);
UpdateStu s4=new UpdateStu("马同学", 01012);
TreeSet<UpdateStu> tree=new TreeSet<>();
tree.add(s1);
tree.add(s2);
tree.add(s3);
tree.add(s4);
Iterator<UpdateStu> kk=tree.iterator();
while (kk.hasNext()) {
UpdateStu jk=(UpdateStu) kk.next();
System.out.println(jk.getId()+"***"+jk.getName());
}
kk=tree.headSet(s2).iterator();//截图排在s2对象之前的对象
System.out.println("截取前部分的集合");
while (kk.hasNext()) {
UpdateStu ll=(UpdateStu) kk.next();
System.out.println(ll.getId()+"***"+ll.getName());
}
kk=tree.subSet(s2, s3).iterator();//截取拍换在s2和s3直接的对象
System.out.println("截取中间部分的集合");
while (kk.hasNext()) {
UpdateStu up= (UpdateStu) kk.next();
System.out.println(up.getId()+"***"+up.getName());
}
}
}
必须继承comparable接口,使用TreeSet接口
第二,headSet ,subSet,tailSet接口传入的参数不包括第二个参数的值,但是包含第一个参数的值.