Wie kann ich diese umschreiben:Java: Rewrite Vergleich Lambda - Nullsafe
private Comparator<Domain> byRank;
...
byRank = new Comparator<Domain>() {
@Override
public int compare(Domain d1, Domain d2) {
float tmp1 = d1.getDomainRank() == null ? 0 : d1.getDomainRank();
float tmp2 = d2.getDomainRank() == null ? 0 : d2.getDomainRank();
return Float.compare(tmp1, tmp2);
}
};
in Lambda?
Nach check null value before sorting using lambda expression, habe ich versucht, diese:
byRank = Comparator.nullsFirst(Comparator.comparing(Domain::getDomainRank));
Es ist jedoch nicht mit:
java.lang.NullPointerException: null
at java.util.Comparator.lambda$comparing$77a9974f$1(Comparator.java:469)
at java.util.Comparators$NullComparator.compare(Comparators.java:83)
at java.util.PriorityQueue.siftUpUsingComparator(PriorityQueue.java:669)
at java.util.PriorityQueue.siftUp(PriorityQueue.java:645)
at java.util.PriorityQueue.offer(PriorityQueue.java:344)
at java.util.PriorityQueue.add(PriorityQueue.java:321)
bearbeiten: das Lambda versagt, auch wenn ich für null vor dem Vergleich verglichenen Objekte überprüfen:
Queue<Domain> topByRank = new PriorityQueue<>(TOP, byRank);
...
for (Domain domain : domains) {
if (domain == null) { // check here
continue;
}
topByRank.add(domain); // here it fails
}
Für was ich sehe d1 oder d2 sollte Null sein – freedev
@freedev Ich überprüfe für Null-Objekt (siehe bearbeiten). Und die Nicht-Lambda-Version funktioniert ohne Fehler. Würde es nicht auch bei d1.getDomainRank() oder d2.getDomainRank() fehlschlagen? – Michal
Comparator.comsparing wirft die NPE. Sie müssen die Anrufe umdrehen. Siehe http://stackoverflow.com/a/28500970/982149 – Fildor