TreeSet只添加一个值?

0o'*_*'o0 3 java collections set treeset

我是 Java 集合的新手。我有三个类,即MyData、Initializer 和 SetBasics

我创建了一个 HashSet 和一个 TreeSet。现在的问题是 HashSet 工作正常,但 TreeSet 只存储一个值。

这是我的课程

类 MyData

`包 collectionsWorkUp.setDemos;

公共类 MyData 实现 Comparable{

MyData(){   
}

MyData(String n, String p, String eM, long mn, char s){
    name = n;
    profession = p;
    email = eM;
    mobileNo = mn;
    sex =  s;
}


private String name;
private String profession;
private String email;
private long mobileNo;
private char sex;


public String getName() {
    return name;
}
public void setName(String name) {
    this.name = name;
}
public String getProfession() {
    return profession;
}
public void setProfession(String profession) {
    this.profession = profession;
}
public String getEmail() {
    return email;
}
public void setEmail(String email) {
    this.email = email;
}
public long getMobileNo() {
    return mobileNo;
}
public void setMobileNo(long mobileNo) {
    this.mobileNo = mobileNo;
}
public char getSex() {
    return sex;
}
public void setSex(char sex) {
    this.sex = sex;
}

@Override
public int compareTo(MyData o) {
    // TODO Auto-generated method stub
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

}`

类初始化器

包集合WorkUp.setDemos;

公共类初始化器{

/**
 * @param args
 */
public static void main(String[] args) {

    System.out.println("Initializing");

    SetBasics operate = new SetBasics();

    operate.DataInSet();
    operate.printDataInSet(operate.getUsersInHash());

    System.out.println("\n\nPrinting Data in Tree Set--------------------");
    operate.printDataInSet(operate.getUsersInTree());

    System.out.println("\n\n--------Program Terminated----------");

}
Run Code Online (Sandbox Code Playgroud)

}

类 SetBasics

包集合WorkUp.setDemos;

导入java.util.HashSet;导入java.util.Set;导入java.util.TreeSet;

公共类SetBasics{

    private Set<MyData> usersInHash = new HashSet<MyData>();
    private Set<MyData> usersInTree =  new TreeSet<MyData>();

    MyData d1= new MyData(d1's data -data include name, #, profession etc check MyData Class);
    MyData d2=  new MyData(d2's data);
    MyData d3=  new MyData(d3's data);
    MyData d4= new MyData(d4's data);
    MyData d5= new MyData(d5's data);
    MyData d6= new MyData(d6's data);
    MyData d7= new MyData(d7's data);
    MyData nullUser = null;

    public Set<MyData> getUsersInHash() {
        return usersInHash;
    }

    public Set<MyData> getUsersInTree() {
        return usersInTree;
    }

public SetBasics(){ }

public void DataInSet(){

    {
        System.out.println("Adding Data in HashSet");
        System.out.println("Data in HashSet Before Adding Element:" + usersInHash.size());
        setDataInSet(nullUser);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(d7);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(d6);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(d5);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(d4);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(d3);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(d2);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(d1);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
        setDataInSet(null);
        System.out.println("Data in HashSet After Adding Element:" + usersInHash.size());
    }

    {
        System.out.println("Adding Data in TreeSet");
        System.out.println("Users in Tree after Before Data:"+usersInTree.size());
        setDataInTreeSet(d7);
        System.out.println("Users in Tree after Adding Data:"+usersInTree.size());
        setDataInTreeSet(d6);
        System.out.println("Users in Tree after Adding Data:"+usersInTree.size());
        setDataInTreeSet(d5);
        System.out.println("Users in Tree after Adding Data:"+usersInTree.size());
        setDataInTreeSet(d4);
        System.out.println("Users in Tree after Adding Data:"+usersInTree.size());
        setDataInTreeSet(d3);
        System.out.println("Users in Tree after Adding Data:"+usersInTree.size());
        setDataInTreeSet(d2);
        System.out.println("Users in Tree after Adding Data:"+usersInTree.size());
        setDataInTreeSet(d1);
        System.out.println("Users in Tree after Adding Data:"+usersInTree.size());

        printDataInSet(usersInTree);
    }

}

public void setDataInSet(MyData userDetails){
    System.out.println("Setting Data in HashSet");
    usersInHash.add(userDetails);       
}

public void setDataInTreeSet(MyData userDetails){
    System.out.println("Setting Data in TreeSet");
    usersInTree.add(userDetails);
}

public void printDataInSet(Set<MyData> s){
    System.out.println("Printing Data");
    System.out.println("Size of the Set:"+s.size());
    for(MyData itorator: s){
        try{
            System.out.println("User Details:______");
            System.out.println("Name:"+itorator.getName());
            System.out.println("Mobile Number:"+itorator.getMobileNo());
            System.out.println("eMail:"+itorator.getEmail());
            System.out.println("Profession:"+itorator.getProfession());
            System.out.println("Sex:"+itorator.getSex());

        }catch(NullPointerException npe){
            System.out.println(npe.getMessage());
            npe.getStackTrace();
        }finally{
            System.out.println("EOD_____\n");
        }

    }

}
Run Code Online (Sandbox Code Playgroud)

}

现在问题出在 TreeSet 中,我只能看到 d7 的数据,而没有其他任何内容添加到 TreeSet

Pau*_*ora 5

TreeSet使用您的MyData.compareTo实现来比较元素。但你还没有实现它——它总是会返回0。据我们所知TreeSet,所有MyData对象都是平等的。compareTo有关详细信息,请参阅javadoc。

请注意, 之所以HashSet有效,是因为它使用了hashCodeequals。与 不同的是compareTo,它们在类中具有默认实现Object,这些实现基于引用相等性。我建议您重写这两种方法并使其基于字段MyData。事实上,MyData具有相同数据的两个不同对象将不会被视为相等。(大多数 IDE 可以根据指定字段自动生成良好hashCode并覆盖。)equals