java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java 异步实现方式

Java 中实现异步的多种方式

作者:北冥SP

文章介绍了Java中实现异步处理的几种常见方式,每种方式都有其特点和适用场景,通过选择合适的异步处理方式,可以提高程序的性能和可维护性,感兴趣的朋友一起看看吧

在 Java 中实现异步处理有多种方式,每种方式都有其特定的适用场景和优缺点。以下是几种常见的实现异步处理的方式:

1. 线程池(ExecutorService)

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExample {
    public static void main(String[] args) {
        ExecutorService executor = Executors.newFixedThreadPool(2);
        Runnable task1 = () -> {
            System.out.println("Task 1 running in thread: " + Thread.currentThread().getName());
        };
        Runnable task2 = () -> {
            System.out.println("Task 2 running in thread: " + Thread.currentThread().getName());
        };
        executor.execute(task1);
        executor.execute(task2);
        executor.shutdown();
    }
}

2. CompletableFuture

import java.util.concurrent.CompletableFuture;
public class CompletableFutureExample {
    public static void main(String[] args) {
        CompletableFuture.supplyAsync(() -> {
            System.out.println("Task 1 running in thread: " + Thread.currentThread().getName());
            return "Result 1";
        }).thenApply(result -> {
            System.out.println("Task 2 running in thread: " + Thread.currentThread().getName());
            return result + " processed";
        }).thenAccept(finalResult -> {
            System.out.println("Final result: " + finalResult);
        });
        // 防止主线程提前结束
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

3. ForkJoinPool

import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.RecursiveTask;
public class ForkJoinExample extends RecursiveTask<Integer> {
    private final int threshold = 2;
    private final int start;
    private final int end;
    public ForkJoinExample(int start, int end) {
        this.start = start;
        this.end = end;
    }
    @Override
    protected Integer compute() {
        if (end - start <= threshold) {
            int sum = 0;
            for (int i = start; i < end; i++) {
                sum += i;
            }
            return sum;
        } else {
            int middle = (start + end) / 2;
            ForkJoinExample subtask1 = new ForkJoinExample(start, middle);
            ForkJoinExample subtask2 = new ForkJoinExample(middle, end);
            subtask1.fork();
            subtask2.fork();
            return subtask1.join() + subtask2.join();
        }
    }
    public static void main(String[] args) {
        ForkJoinPool pool = new ForkJoinPool();
        ForkJoinExample task = new ForkJoinExample(1, 100);
        int result = pool.invoke(task);
        System.out.println("Result: " + result);
    }
}

4. Callable 和Future

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class CallableFutureExample {
    public static void main(String[] args) {
        ExecutorService executor = Executors.newSingleThreadExecutor();
        Callable<Integer> task = () -> {
            Thread.sleep(2000);
            return 42;
        };
        Future<Integer> future = executor.submit(task);
        try {
            Integer result = future.get();
            System.out.println("Result: " + result);
        } catch (InterruptedException | ExecutionException e) {
            e.printStackTrace();
        }
        executor.shutdown();
    }
}

5. ScheduledExecutorService

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class ScheduledExecutorExample {
    public static void main(String[] args) {
        ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
        Runnable task = () -> {
            System.out.println("Task running in thread: " + Thread.currentThread().getName());
        };
        // 延迟2秒后执行任务
        scheduler.schedule(task, 2, TimeUnit.SECONDS);
        // 每隔1秒执行一次任务
        scheduler.scheduleAtFixedRate(task, 0, 1, TimeUnit.SECONDS);
        // 防止主线程提前结束
        try {
            Thread.sleep(10000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        scheduler.shutdown();
    }
}

总结

根据具体需求选择合适的异步处理方式,可以提高程序的性能和可维护性。希望这些示例对你有所帮助!如果有更多问题或需要进一步的帮助,请随时提问。

到此这篇关于Java 中实现异步的方式的文章就介绍到这了,更多相关Java 异步内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文