0

我正在尝试比较同一类的一堆对象以搜索匹配的 ID?这是 GroupClass,当输入新条目时,它将针对 idNumber 进行测试以查看是否匹配。

Public GroupClass {

private int idNumber;
private String name;
private double income;


public GroupClass(int id, String name, double income){
    this.idNumber = id;
    this.name = name;
    this.income = income;
}

public int getIdNumber() {
    return idNumber;
}

public void setIdNumber(int idNumber) {
    this.idNumber = idNumber;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public double getIncome() {
    return income;
}

public void setIncome(double income) {
    this.income = income;
 }
}

这是主要方法

import static java.lang.reflect.Array.set;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Scanner;
import java.util.Set;


    public class ListTester {
    public static void main(String[] args) {
    Scanner input = new Scanner(System.in);

    Set<GroupClass> groupArray = new LinkedHashSet<>();
    System.out.println("Enter a ID Number");
    int id = input.nextInt();
    System.out.println("Enter a First Name");
    String name = input.next();
    System.out.println("Enter a an Income");
    double income = input.nextDouble();


    groupArray.add(new GroupClass(1111, "Billy", 178000));
    groupArray.add(new GroupClass(1112, "Sam", 78000));
    groupArray.add(new GroupClass(1113, "Mark", 79000));

    groupArray.add(new GroupClass(id, name, income));
    printTheClass(groupArray);


}

public static void printTheClass(Set group){
    for(Object theArray: group){
        System.out.println(theArray + " ");
    }
}

}

我已经看到了一些类似的问题,但无法让它适用于我的特定情况,在此先感谢。

4

2 回答 2

1

根据上面的评论,您覆盖了该equals方法,但这可能不适合该类的长期增长。

但是使用您现有的代码尝试

public static void printTheClass(Set<GroupClass> group){
    for(GroupClass theArray: group){
        System.out.println(theArray + " ");
    }
}

public static GroupClass findTheClass(Set<GroupClass> group, int id){
    for(GroupClass obj: group){
        if(obj.getIdNumber == id) return obj;
    }
    return null;
}

这可以用作

if (findTheClass (groupArray, id) == null) {
  groupArray.add (new GroupClass(id, name, income));
}
于 2016-08-26T06:41:48.240 回答
0

不太确定你的目标是什么。如果要在 id 已存在的情况下拒绝任何新条目,则需要覆盖 的hashCodeandequals方法,GroupClass以便LinkedHashSet知道两个GroupClass对象是否不同:

@Override
public int hashCode() {
    return this.idNumber;
}

@Override
public boolean equals(Object obj) {
    return obj instanceof GroupClass && ((GroupClass) obj).getIdNumber() == this.idNumber;
}

但是,在大多数情况下,您可能希望使用其 ID 号检索条目。那么最好使用以 id 作为键的映射,并将 GroupoClass 对象本身作为值

Map<Integer, GroupClass> groupmap = new HashMap<>()
groupmap.put(id, new GroupClass(id, name, income));

你将不得不使用groupmap.keySet()来迭代地图。

于 2016-08-26T06:55:57.807 回答