国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java TreeSet 添加失敗的解決

Java TreeSet 添加失敗的解決

2020-09-29 00:40予悅君兮善窈窕 Java教程

這篇文章主要介紹了Java TreeSet 添加失敗的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

JavaTreeSet 是Set的一個子類。

Set、List、Map區別

Set是一個無序、不允許重復的集合。

List(ArrayList、Vector等)是有序、可重復的。

Map(HashMap等)是鍵值對。

?
1
2
3
4
5
6
7
8
9
public static void demo() {
    TreeSet<Person> ts = new TreeSet<>();
    ts.add(new Person("張三", 23));
    ts.add(new Person("李四", 13));
    ts.add(new Person("周七", 13));
    ts.add(new Person("王五", 43));
    ts.add(new Person("趙六", 33));
    System.out.println(ts);
  }

此處會報異常,異常類型為java.lang.ClassCastException

這是因為Person類沒有實現Comparable 接口,并實現compareTo函數。

compareTo函數就是TreeSet用來判斷是否唯一的函數。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
public class TreeEntity implements Comparable<Object> {
    @JsonProperty(value = "Name")
    private String name = "";
 
    /**
     * 名稱(字段名)
     *
     */
    public final String getName() {
      return name;
    }
 
    public final void setName(String value) {
      name = value;
    }
 
    @JsonProperty(value = "Header")
    private String header = "";
 
    /**
     * 顯示的名稱(字段別名)
     */
    public final String getHeader() {
      if (header.isEmpty()) {
        header = name;
      }
      return header;
    }
 
    public final void setHeader(String value) {
      header = value;
    }
 
    @Setter(AccessLevel.PROTECTED)
    @JsonProperty(value = "Childrens")
    private TreeSet<TreeEntity> childrens;
 
    /**
     * 子節點集合
     *
     */
    public final TreeSet<TreeEntity> getChildrens() {
      return childrens;
    }
 
    public final void setChildrens(TreeSet<TreeEntity> value) {
      childrens = value;
    }
 
    @Override
    public int compareTo(Object o) {
      TreeEntity te = (TreeEntity) o;
      if (te == null)
        return 1;
      return this.getName().compareTo(te.getName());
    }
 
    /**
     * 構造函數
     */
    public TreeEntity() {
      childrens = new TreeSet<TreeEntity>();
    }
  }
  }
}

 

入上圖中的TreeEntity類重寫了compareTo函數,則是通過name屬性來判斷是否唯一。

在TreeSet.add()函數中,會觸發此compareTo函數,如果判斷不唯一,不會添加進去,但是代碼不會報異常。

compareTo函數返回值說明:

為什么返回0,只會存一個元素,返回-1會倒序存儲,返回1會怎么存就怎么取呢?原因在于TreeSet底層其實是一個二叉樹機構,且每插入一個新元素(第一個除外)都會調用compareTo()方法去和上一個插入的元素作比較,并按二叉樹的結構進行排列。

1. 如果將compareTo()返回值寫死為0,元素值每次比較,都認為是相同的元素,這時就不再向TreeSet中插入除第一個外的新元素。所以TreeSet中就只存在插入的第一個元素。

2. 如果將compareTo()返回值寫死為1,元素值每次比較,都認為新插入的元素比上一個元素大,于是二叉樹存儲時,會存在根的右側,讀取時就是正序排列的。

3. 如果將compareTo()返回值寫死為-1,元素值每次比較,都認為新插入的元素比上一個元素小,于是二叉樹存儲時,會存在根的左側,讀取時就是倒序序排列的。

補充知識:compareTo方法重寫錯誤導致TreeSet中無法添加對象

問題描述:

定義了一個實現Comparable接口的類R,包含一個int變量count。在測試類中添加了一個count為-3的對象后,便無法添加count為1的對象。但是可以添加count比-3小的和count為正數的R對象。

錯誤原因:

compareTo方法重寫錯誤。

代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
package test20160302;
import java.util.TreeSet;
class R implements Comparable<Object>{
  int count;
  public R(int count){
    this.count = count;
    System.out.println("count:"+count);
  }
  public String toString(){
    return "R[count:"+this.count+"]";
  }
  public boolean equals(Object obj){
    if(this == obj)return true;
    if(obj!=null && obj.getClass()==R.class){
      return this.count == ((R)obj).count;
    }else
      return false;
  }
 
  public int compareTo(Object obj){
    R r = (R)obj;
    System.out.println("用來比較的數:"+this.count);
    System.out.println("被比較的數:"+r.count);
    return this.count<r.count?-1:this.count>1?1:0;
  }
}
 
public class TreeSetTest3 {
  public static void main(String[] args) {
    TreeSet ts = new TreeSet();
    ts.add(new R(-3));
    ts.add(new R(-1));
    System.out.println(ts);
  }
}

輸出:

count:-3

用來比較的數:-3

被比較的數:-3

count:-1

用來比較的數:-1

被比較的數:-3

[R[count:-3]]

測試:

- 只添加-3,9,1無法添加

- 只添加9,除0外均可以添加。

- 添加-2,9后,1無法添加

- 添加-1,9后,1無法添加

- 添加-1,2后,1無法添加

- 添加-3后,-1無法添加

- 添加-1后,-3無法添加

以上這篇Java TreeSet 添加失敗的解決就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/loveyou388i/article/details/80134346

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品亚洲精品 | 日韩一区二区免费电影 | 超碰毛片 | 日韩精品电影 | 久久人爽 | 亚洲国产中文字幕 | 亚洲国产精品一区二区久久 | 亚洲欧美日韩一区 | 亚洲精品日本 | 91福利资源站 | 久久久久久久久久久网站 | 在线观看特色大片免费网站 | 91超碰在线观看 | а天堂中文最新一区二区三区 | 精品视频网站 | 国产精品一级 | 波多野结衣一区二区三区 | 欧美视频一二三区 | 五月天婷婷综合 | 免费观看日韩 | 亚洲精品电影在线观看 | 在线视频一区二区三区 | 啵啵影院午夜男人免费视频 | 国产aⅴ | 不用播放器的毛片 | 特级淫片日本高清视频免费 | 欧美一级欧美三级在线观看 | ririsao久久精品一区 | 国产成人一区二区 | 欧美二区三区 | jizzz日本| 黄色免费看 | 日韩色区 | 国产精品久久久久无码av | 久久这里只有精品免费 | 欧美一二 | 天堂视频在线 | 日本中文字幕在线观看 | 亚洲第1页 | 欧美一区二区免费 | 老丁头电影在线观看 |