java: Set类及子类:TreeSet有序子类,HashSet无序子类

Posted 穆晟铭

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java: Set类及子类:TreeSet有序子类,HashSet无序子类相关的知识,希望对你有一定的参考价值。

Set类及子类:

TreeSet有序子类;

HashSet无序(散列)子类

HashSet子类的内容是没有顺序的,单个元素也不会重复的(对象除外)。

Set<String> allSet = new HashSet<String>();
		allSet.add("a");
		//重复数据
		allSet.add("b");
		allSet.add("b");
		allSet.add("c");
		allSet.add("d");
		//重复数据
		allSet.add("e");
		allSet.add("e");
		allSet.add("f");
		System.out.println(allSet);

  

TreeSet有序:

TreeSet子类实现了SortSet子类(排序)接口,TreeSet接口是可以排序的。

向TreeSet类中添加自定义对象时,该自定义对象需要复写Comparable接口中的CompareTo排序方法,否则会报:类转换异常

java.lang.ClassCastException

可能需要在复写toString()方法,否则打印的时候报错:

[[email protected], [email protected], [email protected]]

例如:

添加数据时,有一个自定义类:Person类,2个元素,Name(名字),age(年龄),如果用年龄排序,重复年龄会被剔除掉

person:

public class Person implements Comparable<Person> {

	private String name;
	private int age;	
	
	
	public Person(String name, int age) {		
		this.name = name;
		this.age = age;
	}

	public String getName() {
		return name;
	}
	
	public void setName(String name) {
		this.name = name;
	}
	
	public int getAge() {
		return age;
	}
	
	public void setAge(int age) {
		this.age = age;
	}
		
	
	
	@Override
	public String toString() {
		return "姓名:" + name + ", 年龄:" + age + "";
	}

	public int compareTo(Person o) {
		// TODO 自动生成的方法存根
		if(this.age > o.age)
		{
			return 1;
		}else if(this.age < o.age)
		{
			return -1;
		}else{
			return 0;
		}
	}
	
	
}

  

setdemo2:

Set<Person> allSet = new TreeSet<Person>();
		
		allSet.add(new Person("张三",30));
		allSet.add(new Person("李四",30));
		allSet.add(new Person("王五",31));
		allSet.add(new Person("赵六",31));
		allSet.add(new Person("田七",32));
		
		System.out.println(allSet);

  

结果如下:

[姓名:张三, 年龄:30, 姓名:王五, 年龄:31, 姓名:田七, 年龄:32]

  

 

所以,应该复写除了排序Comparable的CompareTo方法外,还应该实现:equles(),

 

以上是关于java: Set类及子类:TreeSet有序子类,HashSet无序子类的主要内容,如果未能解决你的问题,请参考以下文章

Java类集-set

java中的treeset是实现了sortedset接口的set,但为啥要叫treeset呢?

java第八章:集合容器之Set接口

JAVA-初步认识-常用对象API(集合框架-treeset集合)

JAVA集合差异

javaio流之字符输入流:java.io.Reader类及子类的子类java.io.FileReader