如何查看对象列表以查找匹配项?

时间:2016-08-26 06:33:43

标签: java hashset linkedhashset

我正在尝试比较同一类的一堆对象来搜索匹配的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 + " ");
    }
}

}

我已经看过一些像这样的问题,但是不能让它适合我的特定情况,提前谢谢。

2 个答案:

答案 0 :(得分: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));
}

答案 1 :(得分:0)

不太确定你的目标是什么。如果您要在ID已存在的情况下拒绝任何新条目,则需要覆盖hashCode的{​​{1}}和equals方法,以便GroupClass知道两个LinkedHashSet 1}}对象是不同的:

GroupClass

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

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

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

,您必须使用Map<Integer, GroupClass> groupmap = new HashMap<>() groupmap.put(id, new GroupClass(id, name, income)); 来迭代地图。