欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java TreeSet 添加失敗的解決

 更新時間:2020年09月28日 10:38:48   作者:予悅君兮善窈窕  
這篇文章主要介紹了Java TreeSet 添加失敗的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

Java 中TreeSet 是Set的一個子類。

Set、List、Map區(qū)別

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

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

Map(HashMap等)是鍵值對。

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);
  }

此處會報(bào)異常,異常類型為java.lang.ClassCastException

這是因?yàn)镻erson類沒有實(shí)現(xiàn)Comparable 接口,并實(shí)現(xiàn)compareTo函數(shù)。

compareTo函數(shù)就是TreeSet用來判斷是否唯一的函數(shù)。

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;

    /**
     * 子節(jié)點(diǎn)集合
     * 
     */
    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());
    }

    /**
     * 構(gòu)造函數(shù)
     */
    public TreeEntity() {
      childrens = new TreeSet<TreeEntity>();
    }
  }
  }
}

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

在TreeSet.add()函數(shù)中,會觸發(fā)此compareTo函數(shù),如果判斷不唯一,不會添加進(jìn)去,但是代碼不會報(bào)異常。

compareTo函數(shù)返回值說明:

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

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

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

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

補(bǔ)充知識:compareTo方法重寫錯誤導(dǎo)致TreeSet中無法添加對象

問題描述:

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

錯誤原因:

compareTo方法重寫錯誤。

代碼:

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("用來比較的數(shù):"+this.count);
    System.out.println("被比較的數(shù):"+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

用來比較的數(shù):-3

被比較的數(shù):-3

count:-1

用來比較的數(shù):-1

被比較的數(shù):-3

[R[count:-3]]

測試:

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

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

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

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

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

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

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

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

相關(guān)文章

  • 利用Java自寫一個生成ID的工具類

    利用Java自寫一個生成ID的工具類

    平時項(xiàng)目中只要涉及表,那么一定能接觸到眾多各式各樣的ID編號。本文將通過Java語言實(shí)現(xiàn)手寫一個ID生成工具類,需要的小伙伴可以參考一下
    2022-11-11
  • java簡單手寫版本實(shí)現(xiàn)時間輪算法

    java簡單手寫版本實(shí)現(xiàn)時間輪算法

    這篇文章主要為大家詳細(xì)介紹了java簡單手寫版本實(shí)現(xiàn)時間輪算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • 四個Java常見分布式鎖的選型和性能對比

    四個Java常見分布式鎖的選型和性能對比

    當(dāng)涉及到分布式系統(tǒng)中的并發(fā)控制和數(shù)據(jù)一致性時,分布式鎖是一種常見的解決方案,本文將對幾種常見的分布式鎖實(shí)現(xiàn)原理、實(shí)現(xiàn)示例、應(yīng)用場景以及優(yōu)缺點(diǎn)進(jìn)行詳細(xì)分析,需要的可以參考一下
    2023-05-05
  • Java?easyexcel使用教程之導(dǎo)出篇

    Java?easyexcel使用教程之導(dǎo)出篇

    EasyExcel是阿里巴巴開源的一個excel處理框架,以使用簡單,節(jié)省內(nèi)存著稱,下面這篇文章主要給大家介紹了關(guān)于Java?easyexcel使用教程之導(dǎo)出篇的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • 詳解Java中日期工具類的操作

    詳解Java中日期工具類的操作

    這篇文章主要為大家詳細(xì)介紹了Java中日期工具類的常見操作,如:字符串和Date互轉(zhuǎn)、字符串和LocalDate互轉(zhuǎn)等,感興趣的小伙伴可以學(xué)習(xí)一下
    2022-11-11
  • java調(diào)用微信現(xiàn)金紅包接口的心得與體會總結(jié)

    java調(diào)用微信現(xiàn)金紅包接口的心得與體會總結(jié)

    這篇文章主要介紹了java調(diào)用微信現(xiàn)金紅包接口的心得與體會總結(jié),有需要的朋友可以了解一下。
    2016-11-11
  • mybatis設(shè)置sql執(zhí)行時間超時時間的方法

    mybatis設(shè)置sql執(zhí)行時間超時時間的方法

    本文主要介紹了mybatis設(shè)置sql執(zhí)行時間超時時間的方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • SpringBoot中的yaml語法及靜態(tài)資源訪問問題

    SpringBoot中的yaml語法及靜態(tài)資源訪問問題

    這篇文章主要介紹了SpringBoot中的yaml語法及靜態(tài)資源訪問問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-07-07
  • 如何用好Java枚舉讓你的工作效率飛起來

    如何用好Java枚舉讓你的工作效率飛起來

    在JDK1.5之前沒有枚舉類型,那時候一般用接口常量來替代,而使用Java枚舉類型enum可以更貼近地表示這種常量,下面這篇文章主要給大家介紹了關(guān)于如何用好Java枚舉讓你的工作效率飛起來的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • Maven導(dǎo)入依賴時爆紅的幾種解決方法

    Maven導(dǎo)入依賴時爆紅的幾種解決方法

    使用idea建立maven項(xiàng)目,maven導(dǎo)入依賴報(bào)紅,本文主要介紹了Maven導(dǎo)入依賴時爆紅的幾種解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04

最新評論