环境:jdk1.8。
关于并发方面的,juc已帮我们提供了很多好用的工具,而谷歌在此基础上做了扩展,使并发编程更容易,这些工具放在guava.jar包中。
本文演示几个简单的案例,见一下guava的效果。
需要先了解的一些技术:juc中的线程池、Excecutors、ExecutorService、Callable、Future
guava maven配置
com.google.guava
guava
27.0-jre
guava中常用几个类
MoreExecutors:提供了一些静态方法,是对juc中的Executors类的一个扩展。Futures:也提供了很多静态方法,是对juc中Future的一个扩展。
案例1:异步执行任务完毕之后回调
packagecom.itsoku.chat34;
importcom.google.common.util.concurrent.ListenableFuture;
importcom.google.common.util.concurrent.ListeningExecutorService;
importcom.google.common.util.concurrent.MoreExecutors;
importlombok.extern.slf4j.Slf4j;
importjava.util.concurrent.ExecutionException;
importjava.util.concurrent.ExecutorService;
importjava.util.concurrent.Executors;
importjava.util.concurrent.TimeUnit;
/**
* 跟着阿里p7学并发,微信公众号:javacode2018
*/
@Slf4j
publicclassDemo1{
publicstaticvoidmain(String[] args)throwsExecutionException, InterruptedException{
//创建一个线程池
ExecutorService delegate = Executors.newFixedThreadPool(5);
try {
ListeningExecutorService executorService = MoreExecutors.listeningDecorator(delegate);
//异步执行一个任务
ListenableFuture submit = executorService.submit(() -> {
log.info("{}", System.currentTimeMillis());
//休眠2秒,默认耗时
TimeUnit.SECONDS.sleep(2);
log.info("{}", System.currentTimeMillis());
return 10;
});
//当任务执行完毕之后回调对应的方法
submit.addListener(() -> {
log.info("任务执行完毕了,我被回调了");
}, MoreExecutors.directExecutor());
log.info("{}", submit.get());
} f