我想制作一个简单的笔记提醒应用程序,当日期是键并且值是文本时,它使用 hashMap。 我有一个 Panel 类(GUI)、哈希表类(Reminder.java)和一个代表我的日期的“MyDateClass.java”。
我的 gui 由 3 个 JComboBox(日、月、年)、一个文本区域和 2 个按钮 - “保存”、“加载”组成。
GUI 面板中的 2 个按钮:
butSave.addActionListener(new ActionListener () {
public void actionPerformed(ActionEvent e) {
MyDateClass chosenDate = new MyDateClass(cbYear.getSelectedIndex()+2013,cbMonth.getSelectedIndex()+1, cb.getSelectedIndex()+1);
if(!remind.isReminderExists(chosenDate)){
remind.save(chosenDate, tfReminder.getText());
System.out.println("reminder doesnt exists");
}}
});
butLoad.addActionListener(new ActionListener () {
public void actionPerformed(ActionEvent e) {
System.out.println("tryin to load");
MyDateClass chosenDate = new MyDateClass(cbYear.getSelectedIndex()+2013,cbMonth.getSelectedIndex()+1, cb.getSelectedIndex()+1);
if(remind.isReminderExists(chosenDate)){
remind.Load(chosenDate);
System.out.println("reminder exists");
}}
});
提醒类:
public class Reminder {
Map<MyDateClass,String> reminderMap;
public Reminder(){
reminderMap = new HashMap<MyDateClass,String>();
}
public boolean isReminderExists(MyDateClass date){
return reminderMap.containsKey(date);
}
public void save(MyDateClass date, String Input){
System.out.println("Trying to save");
reminderMap.put(date, Input);
}
public void Load(MyDateClass date){
System.out.println("Trying to load");
String output;
output = reminderMap.get(date);
System.out.println(output);
}
所以在我按下保存按钮后,我从控制台得到:
Trying to save
reminder doesnt exists
但随后我按下了同一日期的“加载”按钮,
if(remind.isReminderExists(chosenDate))
未触发。
可能是什么问题?
我需要重写 hashCode() 和 equals() 吗?我生成了它们,但我不知道是否以及如何更改 equals() (我是否需要操作它来比较两个日期?如果“this”指的是提醒对象,我该怎么做)
最佳答案
尝试这样的事情。
@Override public boolean equals(Object o) {
if(o == this) return true;
if(!(o instanceof MyDateClass)) return false;
MyDateClass that = (MyDateClass) o;
// use == for primitives
// use .compare for primitive wrappers where available
// use .equals for objects
return this.ivar1 == that.ivar2 &&
this.ivar2 == that.ivar2; //etc...
}
// equal objects must have equal hash codes
@Override public int hashCode() {
int result = 17;
result = 31 * result + ivar1;
result = 31 * result + ivar2;
return result;
}
编写 JUnit 来测试自反、对称、传递和一致的结果。
关于java - 使用以我的对象作为键的 HashMap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20829871/