Сейчас уже с ума сойду, что ему может не нравиться?
Я уже как только не писал эти проверки
Кто-то почему то советует на null проверять так:
(first == solution.first) || (first != null && first.equals(solution.first))
(first == solution.first) Зачем это делать если у нас String?
ПС если добавить эту злосчастную строчку (first == solution.first), то начинает пролазить 4 пункт WTF???package com.javarush.task.task21.task2104;
import java.sql.SQLOutput;
import java.util.HashSet;
import java.util.Objects;
import java.util.Set;
/*
Equals and HashCode
*/
public class Solution {
private final String first, last;
public Solution(String first, String last) {
this.first = first;
this.last = last;
}
public boolean equals(Object o) {
if (o == null) return false;
if (this == o) return true;
if (!(o instanceof Solution)) return false;
Solution solution = (Solution) o;
boolean a = first != null && first.equals(solution.first);
boolean b = last != null && last.equals(solution.last);
return a && b;
}
public int hashCode() {
return 31 * first.hashCode() + last.hashCode();
}
public static void main(String[] args) {
Set<Solution> s = new HashSet<>();
s.add(new Solution("Donald", "Duck"));
Solution s1 = new Solution("Donald", "Duck");
Solution s2 = new Solution("Donald", "Duck");
// System.out.println(s1.hashCode());
// System.out.println(s2.hashCode());
//System.out.println(s1.equals(s2));
System.out.println(s1.hashCode() == s2.hashCode());
//System.out.println(s.contains(new Solution("Donald", "Duck")));
}
}