博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Executor多线程框架使用
阅读量:5820 次
发布时间:2019-06-18

本文共 1814 字,大约阅读时间需要 6 分钟。

转载自:https://www.cnblogs.com/SimpleWu/p/9709272.html

以后再补全

常用接口:

1)创建固定数目线程的线程池:

public static ExecutorService newFixedThreadPool(int nThreads)

2)执行一个线程

void java.util.concurrent.Executor.execute(Runnable command)

3)查看当前活动线程个数

int java.util.concurrent.ThreadPoolExecutor.getActiveCount()

4)结束掉所有的线程

void java.util.concrrent.ExecutorService.shutdonw()

Executor在管理多个线程的时候会进行有效的安排。处理,比如创建的时候线程池里有10个线程,加入实现线程超过10个Executor会进行有效的队列阻塞和调度。对于我们开发者开说这是透明的,完全不需要关心它内部是怎么进行的操作。

实例代码:

package com.java.executor;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.concurrent.ThreadPoolExecutor;public class ExecutorTest {    private static Integer count = 1; //数量        private static boolean flag = true;//是否执行    public static void main(String[] args) {        ExecutorService executorService = Executors.newFixedThreadPool(10);//在连接池中初始化10个线程        while(flag){            if(count<=100){                executorService.execute(new Runnable() {                    @Override                    public void run() {                        System.out.println("执行 : " + count++);                    }                });            }else{                //判断是否有活动线程                if(((ThreadPoolExecutor)executorService).getActiveCount()==0){                    executorService.shutdown();//结束所有线程                    flag=false;                    System.out.println("完成操作");                }            }            try {                Thread.sleep(100);//休息0.1秒            } catch (InterruptedException e) {                e.printStackTrace();            }        }    }}

这是Executor简单的使用方式,方便快捷,学习难度底,在这里我们为什么要休息0.1秒呢,在上面这段代码上我们是没有加锁的,如果不休息在这段代码上等count大于100的时候,线程还在活动中会导致线程没有进行关闭,加上线程执行速度的飞快会超过我们需求,并且在爬虫爬网页的时候使用这么块的速度是很容易封IP的。

转载于:https://www.cnblogs.com/But-you/p/9709541.html

你可能感兴趣的文章
VS“.NET研究”2010测试功能之旅:编码的UI测试(1)
查看>>
善用Wink将电脑操作录屏为Flash文件
查看>>
【转】程序员开发大型应用程序的技巧
查看>>
用银联借记卡通过paypal支付美金
查看>>
访问Android硬件资源の管理网络和Wifi连接
查看>>
原创5:dell sc1425老服务器安装vmware虚拟机esxi 5.0-更新TEAC CD-224E-N Slim CDROM ULD
查看>>
Electron使用与学习--(基本使用与菜单操作)
查看>>
spring mvc上传下载文件
查看>>
Risc-V指令集
查看>>
三种高效率SQL语句分页方法
查看>>
AlertDialog
查看>>
预览本地图片代码(Demo)
查看>>
转载:在64位的环境中使用VS建立Web项目进行Oracle连接需要注意WebDev是32位的
查看>>
【转载]html5使用数据库实现Web留言本
查看>>
利弗莫尔
查看>>
Tempdb数据库详细介绍
查看>>
巧解 JavaScript 中的嵌套替换
查看>>
6个最好的 HTML5/CSS3 演示(PPT)框架
查看>>
vim ctags
查看>>
装饰模式【设计模式学习-03】
查看>>