Java8において、下記のソースで正しく文字数の多い順にソートがされるのですが、リファレンスによるとArrays.sortの仕様は
Array.sort(T[] a, Comparator<? super T> c)
となっており、第二引数にComparatorの実装でないオブジェクトを渡せる理由がわからないのでお教え頂けないでしょうか。
Java
1public class LengthChecker { 2 public static int check(String s1, String s2) { 3 return s2.length() - s1.length(); 4 } 5} 6 7public class Main { 8 public static void main(String[] args) { 9 String[] fruits = new String[]{"orange", "apple", "strawberry"}; 10 Arrays.sort(fruits, LengthChecker::check); 11 System.out.println(Arrays.toString(fruits)); 12 return; 13 } 14}
次のように、Comparatorの実装を第二引数に渡すのであれば理解できます。
Java
1public class Main { 2 public static void main(String[] args) { 3 String[] fruits = new String[]{"orange", "apple", "strawberry"}; 4 Arrays.sort(fruits, (s1, s2) -> s2.length() - s1.length()); 5 System.out.println(Arrays.toString(fruits)); 6 return; 7 } 8}
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/08/02 23:41
2019/08/02 23:44
2019/08/02 23:48