java——集合-set

Set接口

Set继承自Collection接口,set接口中的元素无序,不重复主要有两个实现类HashSet和TreeSet

HashSet集合

Set与List集合的存取方式一样
当向HashSet集合中添加一个对象时首先会调用对象的hashCode()方法来确定元素的存储位置,
然后在调用对象的equals()方法来确保该位置没有重复元素

TreeSet集合

内部采用自平衡的排序二叉树来存储元素
二叉树存储结构首元素放在第一然后进行对比小的放左边大的放右边
如果TreeSet存放对象类型的,必须使对象类型实现Comparable接口才能实现比较

Comparable和Comparator

Comparable
1、表示可以比较的(用于类实现)。
2、实现这个接口表示:这个类的实例可以比较大小,可以进行自然排序。
3、compareTo() 返回正数表示大,返回负数表示小,返回0表示相等。
4、Comparable的实现必须不equals()的结果一致,就是相等的对象时候,比较结果一定是0!
Comparator
1、比较工具。
2、用于临时定义比较规则,不是默认比较规则。

        案例:Comparator
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class CompareDemo {
public static void main(String[] args) {
演示 String 重写的compareTo()方法
int a = "Tom".compareTo("Jerry");
System.out.println(a);
a = "Tom".compareTo("Tom");
System.out.println(a);
a = "Jerry".compareTo("Tom");
System.out.println(a);
List names = new ArrayList();
names.add("Tom");
names.add("Jerry");
names.add("Black");
names.add("Andy");
names.add("Lee");
ByLength byLength = new ByLength();
演示 按照自定义比较规则排序
Collections.sort(names, byLength);
System.out.println(names);
}
}
class ByLength implements Comparator {
@Override
public int compare(String o1, String o2) {
return -(o1.length() - o2.length()); // 按照长度对比
}
}

你可能感兴趣的:(java——集合-set)