我正在尝试比较同一类的一堆对象来搜索匹配的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 + " ");
}
}
}
我已经看过一些像这样的问题,但是不能让它适合我的特定情况,提前谢谢。
答案 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));
来迭代地图。