多线程之Executors基本使用
Executors几种创建方式
https://www.cnblogs.com/yasong/p/9318522.html
线程池数如何设置
https://blog.csdn.net/u013276277/article/details/82630336
https://www.cnblogs.com/cherish010/p/8334952.html
示例
- 实现Runnable方式
public class WorkThread implements Runnable{
private String mobile = "";
private Integer num;
@Override
public void run() {
String reqData = mobile;
try {
System.out.println(Thread.currentThread().getName()+"线程"+"["+num+"]request data :"+reqData);
String respStr = accessScoreService(reqData);
} catch (Exception e) {
System.out.println(e.getMessage());
}
}
/**
* 具体业务处理逻辑
*
* @param reqData
* @return
*/
private String accessScoreService(String reqData) {
return Thread.currentThread().getName()+"线程执行任务";
}
public WorkThread(String _mobile,Integer num){
this.mobile = _mobile;
this.num=num;
}
public WorkThread(){
}
}
测试:
/**
* 测试多线程
*/
@Test
public void testExecutors(){
List<String> mobList=new ArrayList<>();
for(int i=10;i<100;i++){
String tel="186544444"+i;
mobList.add(tel);
}
Integer tps=10;
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(10);
int sleepTime = 1000 / tps;
for(Integer i=0,size=mobList.size();i<size;i++){
String mob=mobList.get(i);
fixedThreadPool.execute(new WorkThread(mob, i));
/*try {
Thread.sleep(sleepTime);
} catch (InterruptedException e) {
e.printStackTrace();
}*/
}
System.out.println("线程初始化完成");
}
- 实现Callable方式
public class WorkForCallable implements Callable<String> {
private String mobile;
@Override
public String call() throws Exception {
System.out.println("************开始执行"+"["+Thread.currentThread().getName()+"]"+"线程=======处理任务:"+mobile);
return "["+Thread.currentThread().getName()+"]"+"线程处理成功";
}
public WorkForCallable(String mobile){
this.mobile=mobile;
}
public WorkForCallable(){
}
}
测试:
@Test
public void testExecutors1() throws InterruptedException, ExecutionException {
List<String> mobList=new ArrayList<>();
for(int i=10;i<100;i++){
String tel="186544444"+i;
mobList.add(tel);
}
List<FutureTask<String>> futureTaskList = new ArrayList<FutureTask<String>>();
ExecutorService excutorService = Executors.newFixedThreadPool(10);
for(int a=0;a<mobList.size();a++){
String str=mobList.get(a);
FutureTask<String> futureTask = new FutureTask<String>(new WorkForCallable(str));
// futureTaskList.add(futureTask);
excutorService.submit(futureTask);
String s = futureTask.get();
System.out.println("************完成结果"+s+"手机号:"+str);
}
}
学习链接
https://blog.csdn.net/m0_37825799/article/details/79088596
https://www.cnblogs.com/zengyuanjun/p/8094610.html
https://blog.csdn.net/majunzhu/article/details/83013780
https://blog.csdn.net/qq_32725403/article/details/79488068
多线程之Executors基本使用的更多相关文章
- java 线程之executors线程池
一.线程池的作用 平时的业务中,如果要使用多线程,那么我们会在业务开始前创建线程,业务结束后,销毁线程.但是对于业务来说,线程的创建和销毁是与业务本身无关的,只关心线程所执行的任务.因此希望把尽可能多 ...
- Java基础-进程与线程之Thread类详解
Java基础-进程与线程之Thread类详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.进程与线程的区别 简而言之:一个程序运行后至少有一个进程,一个进程中可以包含多个线程 ...
- JAVA多线程之UncaughtExceptionHandler——处理非正常的线程中止
JAVA多线程之UncaughtExceptionHandler——处理非正常的线程中止 背景 当单线程的程序发生一个未捕获的异常时我们可以采用try....catch进行异常的捕获,但是在多线程环境 ...
- iOS多线程之8.NSOPeration的其他用法
本文主要对NSOPeration的一些重点属性和方法做出介绍,以便大家可以更好的使用NSOPeration. 1.添加依赖 - (void)addDependency:(NSOperation * ...
- python 线程之 threading(四)
python 线程之 threading(三) http://www.cnblogs.com/someoneHan/p/6213100.html中对Event做了简单的介绍. 但是如果线程打算一遍一遍 ...
- python 线程之 threading(三)
python 线程之 threading(一)http://www.cnblogs.com/someoneHan/p/6204640.html python 线程之 threading(二)http: ...
- python 线程之_thread
python 线程之_thread _thread module: 基本用法: def child(tid): print("hello from child",tid) _thr ...
- Java多线程之ConcurrentSkipListMap深入分析(转)
Java多线程之ConcurrentSkipListMap深入分析 一.前言 concurrentHashMap与ConcurrentSkipListMap性能测试 在4线程1.6万数据的条件下, ...
- 【C#】线程之Parallel
在一些常见的编程情形中,使用任务也许能提升性能.为了简化变成,静态类System.Threading.Tasks.Parallel封装了这些常见的情形,它内部使用Task对象. Parallel.Fo ...
随机推荐
- 往服务器部署thinkphp5代码时要注意 pathinfo的问题
往服务器部署thinkphp5代码时要注意 pathinfo的问题 如果nginx没有做任何设置 要使用?s=/的方式访问地址 只需要修改3个地方就可以了,亲测成功,看代码有注解 location ~ ...
- centos7环境下apache2.2.34的编译安装
.获取apache2..34的源码包 http://archive.apache.org/dist/httpd/httpd-2.2.34.tar.gz .获取apache的编译参数 apache的编译 ...
- 【原创】大数据基础之Spark(1)Spark Submit即Spark任务提交过程
Spark2.1.1 一 Spark Submit本地解析 1.1 现象 提交命令: spark-submit --master local[10] --driver-memory 30g --cla ...
- 【原创】大数据基础之Airflow(1)简介、安装、使用
airflow 1.10.0 官方:http://airflow.apache.org/ 一 简介 Airflow is a platform to programmatically author, ...
- 【原创】大叔经验分享(26)hive通过外部表读写elasticsearch数据
hive通过外部表读写elasticsearch数据,和读写hbase数据差不多,差别是需要下载elasticsearch-hadoop-hive-6.6.2.jar,然后使用其中的EsStorage ...
- vue的配置环境篇
1.电脑已经安装的nodejs和webpack. 2.1)打开cmd.win+r.可以直接输入node -v查看版本.安装淘宝镜像 npm install -g cnpm --registry=ht ...
- 微信支付现金红包接口应用实例代码说明和DEMO详解,适合用来做微信红包营销活动、吸粉利器
本文详细介绍微信红包开发的接口,商户调用接口时,通过指定发送对象以及发送金额的方式发放红包,领取到红包后,用户的资金直接进入微信零钱.后面带有具体调用php实例 总结一下:需要注意的是PEM秘 ...
- Debian Jessie升级至Stretch小记
昨天Debian Stretch正式发布.为了尝新,昨天晚上便从Jessie升到了Stretch.结果,早上起来发现系统已无法进入X视窗环境,且NVIDIA的官方驱动无法成功编译和安装.看来,每次系统 ...
- zabbix4.0构建实录
[Nginx] #wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo [root@centos ...
- Codeforces 628F 最大流转最小割
感觉和昨天写了的题一模一样... 这种题也能用hall定理取check, 感觉更最小割差不多. #include<bits/stdc++.h> #define LL long long # ...