Java 中的 异步编程 和 多线程编程 都是并发编程的技术,但它们在实现方式和适用场景上存在着差异。
特点:
特点:
多线程编程案例: 计算一个数组中所有元素的和。
public class MultithreadingExample { public static void main(String[] args) { int[] array = {1, 2, 3, 4, 5}; int numThreads = 4; // 使用 4 个线程 // 创建一个 AtomicInteger 对象来保存总和,以保证并发安全 AtomicInteger total = new AtomicInteger(); // 创建并启动线程池 ExecutorService executorService = Executors.newFixedThreadPool(numThreads); // 提交计算任务 for (int i = 0; i < array.length; i++) { executorService.submit(() -> { // 计算该元素的贡献 int contribution = array[i] / numThreads; // 对总和进行原子更新 total.addAndGet(contribution); }); } // 关闭线程池 executorService.shutdown(); // 等待线程池完成所有任务 while (!executorService.isTerminated()) { // 等待 } // 打印总和 System.out.println("Total: " + total); } }
异步编程案例: 下载一个文件并打印其内容。
import java.io.IOException; import java.net.URI; import java.net.http.HttpClient; import java.net.http.HttpRequest; import java.net.http.HttpResponse; import java.util.concurrent.CompletableFuture; public class AsyncProgrammingExample { public static void main(String[] args) { // 异步下载文件 HttpClient client = HttpClient.newHttpClient(); URI uri = URI.create("http://path/to/file.txt"); HttpRequest request = HttpRequest.newBuilder(uri).GET().build(); CompletableFuture<HttpResponse<String>> responseFuture = client.sendAsync(request, HttpResponse.BodyHandlers.ofString()); // 在后台执行下载操作 responseFuture.thenAccept(response -> { // 当下载完成时,打印文件内容 System.out.println("File contents: " + response.body()); }); } }
多线程编程适合于高度并发的计算任务,而异步编程更适用于 I/O 操作或依赖外部资源的任务。两者的选择取决于具体的场景和性能需求。