《Java核心技术I》并行数组算法

并行数组算法

Arrays类提供了大量并行化操作。

Arrays.parallelSort方法可以对一个基本类型值或对象的数组排序。

java 复制代码
package arrays;

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.Arrays;
import java.util.Comparator;

public class ParallelSortTest {

    public static void main(String[] args) throws IOException {
        var contents = new String(
                Files.readAllBytes(Path.of("D:\\ChromeCoreDownloads\\eclipse-jee-2024-09-R-win32-x86_64\\eclipse\\eclipse-workspace\\JavaCore1\\src\\arrays\\alice.txt")),StandardCharsets.UTF_8);
//        System.out.println(contents);
        String[] words = contents.split("[\\P{L}]+");
        System.out.println(Arrays.toString(words));
        Arrays.parallelSort(words, Comparator.comparing(String::length));
        System.out.println(Arrays.toString(words));
    }

}

三种:

  • 默认排序:Arrays.parallelSort(words)
  • 提供比较器排序:Arrays.parallelSort(words, Comparator.comparing(String::length));
  • 只排序提供的范围:values.parallelSort(values.length/2,values.length);

parallelSetAll方法会用由一个函数计算得到的值填充一个数组。

java 复制代码
package arrays;

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.Arrays;
import java.util.Comparator;

public class ParallelSetAllTest {

    public static void main(String[] args) throws IOException {
        int[] values = new int[20];
        Arrays.parallelSetAll(values, i->i+1);
        System.out.println(Arrays.toString(values));
    }

}
//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]

最后一个parallelPrefix方法,用一个给定结合操作的相应前缀的累加结果替换各个数组元素。

java 复制代码
package arrays;

import java.util.Arrays;

public class ParallelPrefixTest {

    public static void main(String[] args) {
        int[] values = new int[] {1,2,3,4,5,6,7,8,9}; 
        Arrays.parallelPrefix(values, (x,y)->x+y);
        System.out.println(Arrays.toString(values));
    }

}
//[1, 3, 6, 10, 15, 21, 28, 36, 45]
相关推荐
二哈喇子!6 分钟前
空指针异常
开发语言
咚为12 分钟前
Rust Print 终极指南:从底层原理到全场景实战
开发语言·后端·rust
jaray14 分钟前
PyCharm 2024.3.2 Professional 如何更换 PyPI 镜像源
ide·python·pycharm·pypi 镜像源
%xiao Q17 分钟前
GESP C++五级-202406
android·开发语言·c++
Psycho_MrZhang18 分钟前
Neo4j Python SDK手册
开发语言·python·neo4j
Traced back25 分钟前
# C# + SQL Server 实现自动清理功能的完整方案:按数量与按日期双模式
开发语言·c#
sin220129 分钟前
MyBatis的执行流程
java·开发语言·mybatis
web3.088899941 分钟前
1688图片搜索API,相似商品精准推荐
开发语言·python
二哈喇子!41 分钟前
JAVA环境变量配置步骤及测试(JDK的下载 & 安装 & 环境配置教程)
java·开发语言
少云清1 小时前
【性能测试】15_JMeter _JMeter插件安装使用
开发语言·python·jmeter