我不确定这个小例子是否有语法错误,或者NetBeans 8.1 /Java8更新66是否有问题。这里的目标是使用lambda比较(而不是使用自定义比较),如下所示:
java: Arrays.sort() with lambda expression
最终的目标是使用lambda比较,根据一个值数组对一个索引数组(0到n-1)进行排序。通过irfani arief提供的使用Integer而不是int的答案,这个问题中的第三个代码示例可以做到这一点。
我使用类似的语法,但在使用lambda表达式的行上出现了一个错误。我已经尝试过与问题和答案相关的变化,但是还没有起作用。
package x;
import java.util.Arrays;
public class x {
public static void main(String[] args) {
int[] A = {3, 1, 2, 0};
Arrays.sort(A, (a, b) -> a-b); //error on this line
for(int i = 0; i < 4; i++)
System.out.println(A[i]);
}
}伊法尼·阿里夫回答说,改为Integer解决了这个问题。
package x;
import java.util.Arrays;
public class x {
public static void main(String[] args) {
Integer[] A = {3, 1, 2, 0};
Arrays.sort(A, (a, b) -> a-b);
for(int i = 0; i < 4; i++)
System.out.println(A[i]);
}
}这才是真正的目标,使用lambda比较法根据一系列值对索引数组进行排序,类似于使用C++ std::sort使用lambda比较的方式。只有索引数组需要为Integer类型,值数组可以是基元类型。
package x;
import java.util.Arrays;
public class x {
public static void main(String[] args) {
int[] A = {3, 1, 2, 0};
Integer[] I = {0, 1, 2, 3};
Arrays.sort(I, (i, j) -> A[i]-A[j]);
for (Integer i : I) {
System.out.println(A[i]);
}
}
}发布于 2016-01-05 06:25:53
首先,无论是谁,在点击重复按钮之前,请阅读整个问题。这个人在询问如何在lambda中完成这个任务(他可能正在学习java 8),而不是问如何排序一个整数。
答案是,java 8上的lambda操作似乎不适用于原语,因为被替换的比较器需要将其放在<>中,例如Comparator<? super T>,其中T是要比较的类型。
所以解决方案很简单,只需将int[]部件更改为Integer[]
https://stackoverflow.com/questions/34605405
复制相似问题