Java 在并行编程中应用函数接口
引言
并行编程是一种编程技术,允许多处理器同时工作。函数接口在并行编程中起着至关重要的作用,因为它允许我们创建和传输无状态代码块,以便于并行执行。
函数式接口
立即学习“Java免费学习笔记(深入);
函数接口是一种只有一种抽象方法的接口。它将输入映射到输出。Java 常用的函数接口包括:
- Runnable(无参数,无返回值)
- Callable(有参数,有返回值)
- Consumer(消费输入而不产生输出)
- Supplier(不接受参数,产生输出)
并行编程示例
示例:使用 Runnable 创建并行线程
import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class ParallelRunnable { public static void main(String[] args) { ExecutorService executor = Executors.newFixedThreadPool(10); for (int i = 0; i < 100; i++) { executor.execute(() -> System.out.println("Thread " + Thread.currentThread().getName())); } executor.shutdown(); } }
示例:使用 Callable 创建并行任务
import java.util.concurrent.*; public class ParallelCallable { public static void main(String[] args) throws ExecutionException, InterruptedException { ExecutorService executor = Executors.newFixedThreadPool(10); List<Callable<Integer>> tasks = new ArrayList<>(); for (int i = 0; i < 100; i++) { tasks.add(() -> { Thread.sleep(100); return i; }); } List<Future<Integer>> results = executor.invokeAll(tasks); for (Future<Integer> result : results) { System.out.println(result.get()); } executor.shutdown(); } }
总结
Java 函数接口为并行编程提供了强大的工具。它们允许我们平行创建和传输无状态代码块,以提高应用程序的性能和并发性。
以上是Java函数接口在并行编程中应用的详细内容。请关注图灵教育的其他相关文章!