package com.net.xinfang.reflect;
import java.util.Comparator;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
import java.util.TreeSet;
/***
* Set集(HashSet)
*
* @author xinfang
*
*/
public class set008 {
public void set() {
Set<String> set = new HashSet<String>();
set.add("1");// 添加元素
set.add("2");
set.remove("1");//移除元素
set.contains("2");//判断是否包含元素
set.equals("2");//判断是否有与2相等的元素
set.size();//获取set的尺寸
set.isEmpty();//判断是否为空,为空-false
set.hashCode();
set.toArray();//转换为数组
// Iterator迭代遍历
Iterator it = set.iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// for增强遍历
for (String st : set) {
System.out.println(st);
}
// TreeSet默认排序
Set<String> se = new TreeSet<String>();
se.add("f");
se.add("a");
se.add("b");
se.add("c");
se.add("d");
se.add("e");
System.out.println(se);
}
// 倒序输出
public void dxSort() {
Set<String> set = new TreeSet<String>(new MyComparator());
set.add("a");
set.add("b");
set.add("c");
set.add("d");
set.add("e");
set.add("A");
for (Iterator<String> iterator = set.iterator(); iterator.hasNext();) {
System.out.print(iterator.next() + " ");
}
}
// 定义新实例
public void newSet() {
Set<Person> set = new TreeSet<Person>(new PersonComparator());
Person p1 = new Person(10);
Person p2 = new Person(20);
Person p3 = new Person(30);
Person p4 = new Person(40);
set.add(p1);
set.add(p2);
set.add(p3);
set.add(p4);
for (Iterator<Person> iterator = set.iterator(); iterator.hasNext();) {
System.out.print(iterator.next().score + " ");
}
}
public static void main(String args[]) {
set008 set8 = new set008();
set8.set();
set8.dxSort();
set8.newSet();
}
}
class MyComparator implements Comparator<String> {
@Override
public int compare(String o1, String o2) {
return o2.compareTo(o1);// 降序排列
}
}
class Person {
int score;
public Person(int score) {
this.score = score;
}
public String toString() {
return String.valueOf(this.score);
}
}
class PersonComparator implements Comparator<Person> {
@Override
public int compare(Person o1, Person o2) {
return o1.score - o2.score;//升序排列
}
}