java.util.Arrays.parallelPrefix() 方法用于并行累积给定数组的每个元素使用提供的函数就位。例如,如果数组最初包含 [2, 1, 0, 3] 并且操作执行加法,则返回时数组包含 [2, 3, 3, 6]。
语法
public static <T> void parallelPrefix(T[] array,
BinaryOperator<T> op)
这里,T是数组中元素的类型。
参数
array | 指定数组,该数组通过此方法就地修改。 |
op | 指定一个无副作用的关联函数来执行累积。 |
返回值
void 类型。
异常
如果指定的数组或函数为 null,则抛出 NullPointerException。
示例:
在下面的示例中,java.util.Arrays.parallelPrefix() 方法用于并行添加给定数组的每个元素。
import java.util.*;
public class MyClass {
//两个Long数相加
static Long MyFunc(Long x, Long y) {
return x + y;
}
public static void main(String[] args) {
//创建一个长数组
Long[] Arr = {1L, 2L, 3L, 4L, 5L};
//打印Arr
System.out.print("Arr contains:");
for(Long i: Arr)
System.out.print(" " + i);
//MyFunc与parallelPrefix方法一起使用
//添加数组的每个元素
Arrays.parallelPrefix(Arr, (a,b) -> MyFunc(a,b));
//打印Arr
System.out.print("\nArr contains:");
for(Long i: Arr)
System.out.print(" " + i);
}
}
上述代码的输出将是:
Arr contains: 1 2 3 4 5
Arr contains: 1 3 6 10 15