HashSet 是没有提供get方法的,但是我们在使用Set的时候要获取对象,因此在HashSet中提供了 Iterator 来实现遍历
迭代器的工作原理:
主要有三个函数:可以认为iter是箭头所在地方,
next(), 指向元素
hasNext(), 判断还有对象吗
remove(), 移除对象
Iterator iter = hashSet.iterator();
while (iter.hasNext()){
String value=(String) iter.next();
System.out.println(value);
}
// 或者
for(Iterator iter = hashSet.iterator();iter.hasNext();){
String value=(String) iter.next();
System.out.println(value);
}
TreeSet :
// 在TreeSet集合中的数据是有序的,每次添加一个对象时会进行比较,所以有需要注意的事项:
import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;
public class TreeSetTest {
public static void main(String[] args) {
// 在TreeSet集合中的数据是有序的
TreeSet treeSet=new TreeSet();
treeSet.add(10);
treeSet.add(20);
treeSet.add(30);
// TreeSet在添加这些能够比较的对象时是可以的,但是在添加一个普通的类的时候是会抛出异常的
// 因此,如果一个类想被加入到TreeSet之中,必须制定排序规则,意味着要实现Comparator接口,
// 实现compare函数
/* 代码会报错,因为在添加Student对象时,TreeSet无法对两个对象进行比较,所以会抛出异常,要实现对比的接口,如下面
TreeSet treeSet1=new TreeSet();
treeSet1.add(new Student("a"));
treeSet1.add(new Student("A"));
*/
TreeSet treeSet1=new TreeSet(new MyCompare());
treeSet1.add(new Student("a"));
treeSet1.add(new Student("A"));
treeSet1.add(new Student("B"));
for (Iterator iter=treeSet1.iterator(); iter.hasNext();){
String s1=((Student) iter.next()).name;
System.out.println(s1);
}
}
}
class Student {
String name;
public Student (String name) {
// TODO Auto-generated constructor stub
this.name = name;
}
}
// Student 对象的对比实现接口,注意不同的对象,其对比方式不同,可以根据我们想要的对比方式进行对比
class MyCompare implements Comparator{
// 实现comparator 中的compare方法
@Override
public int compare(Object o1, Object o2) {
// TODO Auto-generated method stub
Student s1=(Student) o1;
Student s2=(Student) o2;
// 如果s1>s2 返回小于0的数, 如果s1<s2 返回 大于等于0的数
System.out.println(s1.name.compareTo(s2.name));
return s1.name.compareTo(s2.name);
}
}
Collections 和 Arrays 类中的方法都是静态的,可以实现对集合 和 数组进行一系列操作