程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> java Collection 之Set使用說明

java Collection 之Set使用說明

編輯:JAVA編程入門知識

Set

一個不包含重復元素的collection,確切的講,set不包含滿足e1.equals(e2)的元素對e1,e2,並且最多包含一個null元素;

此實現不是同步的,如果多個線程同時訪問一個set,而其中至少一個線程修改了該set,那麼它必須保持外部同步,通常是通過對自然封裝該set的對象執行同步操作來完成,如果不存在這樣的對象,則:Collections.synchronizedSet();  

HashSet

集合中元素無順序,不重復;數據結構是哈希表;

保證元素唯一性的原理:判斷元素的HashCode值是否相同,若相同,還會繼續判斷元素的equals方法,是否為true; 當一個對象被存儲進HashSet集合中後,就不能修改這個對象的那些參與計算哈希值的字段了,如果修改後就會造成內在洩漏;

TreeSet

可以對Set集合中的元素進行排序:

(1)讓元素自身具備比較性,元素需要實現Comparable接口,覆蓋compareTo方法,這種方式也成為元素的自然順序;

(2)元素自身不具備比較性,或者具備的比較性不是所需要的,這時就需要讓集合自身具備比較性。在集合初始化時就有了比較方式[定義比較器(Comparator<>接口),將它作為參數傳給集合的構造函數]

以下兩種方式為TreeSet需要實現的兩種接口

class Obj implements Comparable<Obj> {

 public int compareTo(Obj o)  {

  return this.name.compareTo(o.name);  

} }

class Comptor implements Comparator<ComptorObj> {

 @Override

 public int compare(ComptorObj o1, ComptorObj o2) {

  return o1.name.compareTo(o2.name);

 } }

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved