文章借鉴自:https://cloud.tencent.com/developer/article/1386118
由于不想粘自己代码,所以偷个懒,感觉原作者的代码没有注释,看起来很难受,所以将自己理解的重新发一下。
如有侵权请告知。
前提:
日常开发,有很多场景会使用到多线程,比如,我们解析Excel,如果解析出一个3万条数据的Excel表格,需要两部:
1.我们需要先异步解析出所有的数据,前面写过了如何异步处理任务(Spring Boot---(4)SpringBoot异步处理任务);
2.然后再多线程去处理业务或者插入到数据库;
这里,讲解一下,如何使用多线程,如何调用回调函数。
1.引入pom.xml的依赖
由于后面要用到Guava包下的东西,所以这里先引入一下。
com.google.guava
guava
22.0
最新好像已经更新到27.1了,没有去留意更新了哪些东东,有心的同学可以百度搜一下,都更新了些什么。
2.controller
这里模拟10万条数据,然后多线程处理。
package com.jd.concurrent;
import com.google.common.collect.ImmutableList;
import com.google.common.util.concurrent.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import java.util.*;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
/**
* author:lightClouds917
* date:2018/1/22