Java Comprator.com mparing比較による空の針の異常な解決
Java Comprator.com mparing比較による空の針異常
代替案
Comprator.nullsFirstはコンパレータとしてCompratos.Null Compratorを作成します。
例:
対象のnameフィールドによって不規則な並べ替えが必要です。
並べ替え規則は(PPD>政府>提携)
compring方法は二つの実現があります。
方法1:パラメータは一つだけで、パラメータの種類は関数式インターフェースです。
方法2:
この方法の一般的な型はどのように伝えられていますか?
1、list.stream()の時に獲得したstreamストリームがパンチングを確定しました。この時戻ってくる対象はStreamです。
2、Streamオブジェクトのsorted方法は、コンパレータのタイプが必要です。Obj.calssまたはObjの親タイプです。
3、こちらでは静的方法Comprator.com mparingを呼び出しましたが、静的方法における汎型は伝的パラメータの種類によって決められます。
以上は個人の経験ですので、参考にしていただければと思います。
Comparator.comparing(Department::getOrder)
理由:
public static <T, U extends Comparable<? super U>> Comparator<T> comparing(
Function<? super T, ? extends U> keyExtractor)
{
Objects.requireNonNull(keyExtractor);
return (Comparator<T> & Serializable)
(c1, c2) -> keyExtractor.apply(c1).compareTo(keyExtractor.apply(c2));
}
keyExtractor.apply(c 1)の場合、keyExtractor.apply(c 1).compreto(XX)は空のポインタを異常として報告します。代替案
Comparator.comparing(Department::getOrder, Comparator.nullsFirst(Comparator.naturalOrder()))
代替案の利点:
public static <T, U> Comparator<T> comparing(
Function<? super T, ? extends U> keyExtractor,
Comparator<? super U> keyComparator)
{
Objects.requireNonNull(keyExtractor);
Objects.requireNonNull(keyComparator);
return (Comparator<T> & Serializable)
(c1, c2) -> keyComparator.compare(keyExtractor.apply(c1),
keyExtractor.apply(c2));
}
まずkeyExtractor.appy(c 1)とkeyExtractor.apply(c 2)を取り出して比較器に入れて比較します。Comprator.nullsFirstはコンパレータとしてCompratos.Null Compratorを作成します。
public static <T> Comparator<T> nullsFirst(Comparator<? super T> comparator) {
return new Comparators.NullComparator<>(true, comparator);
}
Compratos.Null Compratorコンパレータのcompreインターフェース実現中の先進行空値判定処理は、空いているために代入コンパレータ比較を行いません。
/**
* Null-friendly comparators
*/
final static class NullComparator<T> implements Comparator<T>, Serializable {
private static final long serialVersionUID = -7569533591570686392L;
private final boolean nullFirst;
// if null, non-null Ts are considered equal
private final Comparator<T> real;
@SuppressWarnings("unchecked")
NullComparator(boolean nullFirst, Comparator<? super T> real) {
this.nullFirst = nullFirst;
this.real = (Comparator<T>) real;
}
@Override
public int compare(T a, T b) {
if (a == null) {
return (b == null) ? 0 : (nullFirst ? -1 : 1);
} else if (b == null) {
return nullFirst ? 1: -1;
} else {
return (real == null) ? 0 : real.compare(a, b);
}
}
@Override
public Comparator<T> thenComparing(Comparator<? super T> other) {
Objects.requireNonNull(other);
return new NullComparator<>(nullFirst, real == null ? other : real.thenComparing(other));
}
@Override
public Comparator<T> reversed() {
return new NullComparator<>(!nullFirst, real == null ? null : real.reversed());
}
}
Compratorの中のcompparing方法の勉強例:
対象のnameフィールドによって不規則な並べ替えが必要です。
並べ替え規則は(PPD>政府>提携)
public class Obj {
private String name;
private BigDecimal price;
......
}
@Test
public void sort() {
List<Obj> list = Arrays.asList(
new Obj(" ", null),
new Obj(" ", new BigDecimal("1216.23")),
new Obj(" ", new BigDecimal("123.23")),
new Obj("PPD", new BigDecimal("123.23")),
new Obj(" ", new BigDecimal("127.23")),
new Obj(null, new BigDecimal("125.23")));
List<String> sortList = Arrays.asList("PPD"," "," ");
List<Obj> result = list.stream().sorted(
// name ( a )
Comparator.comparing(Obj::getName,(x,y)-> {
if(x == null && y != null){
return 1;
}else if(x !=null && y == null){
return -1;
}else if(x == null && y == null){
return -1;
} else {
for(String sort : sortList){
if(sort.equals(x) || sort.equals(y)){
if(x.equals(y)){
return 0;
}else if(sort.equals(x)){
return -1;
}else{
return 1;
}
}
}
return 0;
}
})).collect(Collectors.toList());
System.out.println(result);
}
1.実現compring方法は二つの実現があります。
方法1:パラメータは一つだけで、パラメータの種類は関数式インターフェースです。
方法2:
この方法の一般的な型はどのように伝えられていますか?
1、list.stream()の時に獲得したstreamストリームがパンチングを確定しました。この時戻ってくる対象はStream
2、Streamオブジェクトのsorted方法は、コンパレータのタイプが必要です。Obj.calssまたはObjの親タイプです。
3、こちらでは静的方法Comprator.com mparingを呼び出しましたが、静的方法における汎型は伝的パラメータの種類によって決められます。
以上は個人の経験ですので、参考にしていただければと思います。