さて、リストに要素を追加するメソッドがありますが、作成した要素がなくても、常にカスタム例外をスローしていますSet
。
private Set<Plan> planSet = new HashSet<Plan>();
public Plan createPlan(String name) throws DuplicatePlan{
Plan plan = new Plan(name);
if(!planSet.contains(plan)){
planSet.add(plan);
} else {
throw(new DuplicatePlan("Error, duplicate plan"));
}
return plan;
}
私の方法equals()
とhashCode()
方法がこれを引き起こしていると考えています。現在、私はデフォルトの上書きされたEclipseを使用していますhashCode()
.equals()
これは私がそこに持っているものです:
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj){
return true;
} if (obj == null){
return false;
} if (getClass() != obj.getClass()){
return false;
}
Plan other = (Plan) obj;
if (name == null) {
if (other.name != null){
return false;
}
} else if (!name.equals(other.name)){
return false;
}
return true;
}
これは何をするかPlan
です:
private String name;
private Set<Tables> tablesSet;
public Plan(String name){
this.name = name ;
}
ユーザーが TextField に同じ名前を設定すると、次のようになります。
newPlan.setOnAction(new EventHandler<ActionEvent>(){
@Override
public void handle(ActionEvent action){
if(!newPlan.getText().isEmpty()){
try {
String name = planName.getText();
plan.createPLan(name);
esquema = esquemas.createPlan(planName.getText());
optionsPlans.getItems().add(plan.getName());
} catch (DuplicatePlan e) {
dialog.errorDialog(planError, duplicate);
}
} else {
dialog.errorDialog(empty, emptySpace);
}
}
});