java集合类之Set

   总结一下这两天看的有关Set的东西

   Set是Collection的子类,当中的数据元素是无序不可重复的,Set判断两个对象是否相同不是通过“==”号,而是通过equals方法比较的,也就是说只要equals方法比较返回true,则这两个对象不能同时添加到Set中。

 

public class TestSet {
	public static void main(String[] args) {
		Set books = new HashSet();
		books.add(new String("java"));
		//再添加一个字符串
		boolean result = books.add(new String("java"));
		System.out.println(result);
	}
}
  上述代码将输出false.

    HashSet是Set接口的实现,也是一般经常用的一个。HashSet是按Hash算法来存储集合中的元素的,因此具有很好的查找和存取性能。

     HashSet有一下三个特点:

        1.不能保证元素的顺序,顺序有可能变化;

        2.元素可以为null;

        3.不是线程同步的,如果有多个线程同时修改同一元素,需要用代码进行其同步。

    HashSet是根据对象的HashCode决定对象的存储位置的,当两个对象通过equals方法比较返回true,但他们HashCode值不同,则HashSet将会把这两个对象存储在不同的位置。所以HashSet判断两个对象相等的条件是通过equals方法返回true,且hashcode值也相等。

    Hash算法功能:通过一个对象快速找到另一个对象,hash算法的优点在于迅速,通过一个元素的值就可以得到该元素的存储位置,保证查询快速执行。

 当需要将某个对象保存到HashSet集合里时,当重写equals方法返回true时,也应尽量保证HashCode的值相等。如果在一个集合里出现了几个HashCode值相同的对象,则会导致性能下降。

    LinkedHashSet是HashSet的一个子类,它也是通过HashCode的值来存储元素位置的,不同的是其内部是通过链表来维护元素的顺序,也就是LinkedHashSet里的集合元素的顺序是元素添加时的顺序。因为要用链表进行顺序的维护,所以在性能上低于HashSet。

    TreeSet是SortedSet接口的唯一实现,可以保证集合里的元素是有序的。TreeSet不是根据元素的插入顺序进行排序,而是根据元素的实际值。TreeSet有两种排序规则,是基于红黑树这种数据结构实现的。

    1.自然排序:调用集合的compareTo方法比较元素之间的大小关系,然后将集合进行升序排序,这种排序时默认实现的。

    2.定制排序:如要实现定制排序,如降序,则需要使用Comparator接口。

    EnumSet是一个枚举类 的集合类,该集合里的所有值必须是指定枚举类型的枚举值。EnumSet里的元素是有序的,这种顺序是以枚举值在枚举类中的定义顺序来定义的。EnumSet不允许插入null值,会抛出空指针异常。EnumSet内部以位向量的形式存储,存储形式紧凑、高效,因次其占用内存小,运行效率高。

 

你可能感兴趣的:(java,集合,hash,HashCode,存储)