JavaShuo
栏目
标签
平时使用了哪些线程池
时间 2019-11-16
标签
平时
使用
哪些
线程
繁體版
原文
原文链接
阅读完本篇文章会知道以下三点:
1.进程-线程简单介绍
2.java的线程池是什么,有哪些类型,做用分别是什么
3.使用线程池的优势
1.进程-线程的简单介绍
进程
什么是进程呢?
进程是计算机中的程序关于某数据集合的一次运行活动,是系统进行资源分配的调度的基本单位,是操做系统结构的基础。简单来说:进程是指运行中的应用程序,进程是一个实体,每个进程都有它本身的地址空间。例如咱们点击了QQ,就启动了一个进程,操做系统就会为这个进程分配独立的地址空间,当咱们又点击浏览器,这样又启动了一个进程,操做系统将为新的进程分配新的独立的地址空间。
线程
什么是线程呢?
线程是操做系统可以进行运算调度的最小单位,被包含在进程之中,是进程中的实际运做单位。一个进程至少有一个线程。一条线程指的是进程中一个单一顺序的控制流,一个进程中能够并发多个线程,每条线程并行执行不一样的任务。注意:线程本身不拥有系统资源,只拥有一点在运行中必不可少的资源,但它可与同属于一个进程的其余线程共享进程所拥有的所有资源,线程有就绪,阻塞,运行三种基本状态。
另外:在Unix System和SunOS中也被称为轻量进程,但轻量进程更多指内核线程,而把用户线程称为线程。
2.java的线程池是什么,有哪些类型,做用分别是什么
线程池是一种多线程处理形式,处理过程当中将任务添加队列,而后在建立线程后自动启动这些任务,每一个线程都使用默认的堆栈大小,以默认的优先级运行,并处在多线程单元中,若是某个线程在托管代码中空闲,则线程池将插入另外一个辅助线程来使全部处理器保持繁忙。若是全部线程池都始终保持繁忙,但队列中包含挂起的工做,则线程池将在一段时间后辅助线程的数目永远不会超过最大值。超过最大值的线程能够排队,但他们要等到其余线程完成后才能启动。
java里面的线程池的顶级接口是Executor,Executor并非一个线程池,而只是一个执行线程的工具,而真正的线程池是ExecutorService。
java中的有哪些线程池?
1.newCachedThreadPool建立一个可缓存线程池程
2.newFixedThreadPool 建立一个定长线程池
3.newScheduledThreadPool 建立一个定长线程池
4.newSingleThreadExecutor 建立一个单线程化的线程池
下面一一分析:
1.newCachedThreadPool,是一种线程数量不定的线程池,而且其最大线程数为Integer.MAX_VALUE,这个数是很大的,一个可缓存线程池,若是线程池长度超过处理须要,可灵活回收空闲线程,若无可回收,则新建线程。可是线程池中的空闲线程都有超时限制,这个超时时长是60秒,超过60秒闲置线程就会被回收。调用execute将重用之前构造的线程(若是线程可用)。这类线程池比较适合执行大量的耗时较少的任务,当整个线程池都处于闲置状态时,线程池中的线程都会超时被中止。
实例代码:
public class PoolExecutorTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
ExecutorService mCachelThreadPool = Executors.newCachedThreadPool();
for(int i = 0;i < 7;i++ ) {
final int index = i;
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
mCachelThreadPool.execute(new Runnable() {
@Override
public void run() {
System.out.println("第" +index +"个线程" +Thread.currentThread().getName());
}
});
}
}
}
输出结果:
从结果能够看到,执行第二个任务的时候第一个任务已经完成,会复用执行第一个任务的线程,不用每次新建线程。
2.newFixedThreadPool 建立一个指定工做线程数量的线程池,每当提交一个任务就建立一个工做线程,当线程 处于空闲状态时,它们并不会被回收,除非线程池被关闭了,若是工做线程数量达到线程池初始的最大数,则将提交的任务存入到池队列(没有大小限制)中。因为newFixedThreadPool只有核心线程而且这些核心线程不会被回收,这样它更加快速底相应外界的请求。
实例代码:
public class PoolExecutorTest {
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
//设置最大线程数5个
ExecutorService mFixedThreadPool = Executors.newFixedThreadPool(5);
for(int i = 0;i < 7;i++ ) {
final int index = i;
mFixedThreadPool.execute(new Runnable() {
@Override
public void run() {
System.out.println("时间是:"+System.currentTimeMillis()+"第" +index +"个线程" +Thread.currentThread().getName());
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
}
输出结果:
因为设置最大线程是5,因此当执行完这5个线程后,等待两秒后,在执行后面2个线程。
3.newScheduledThreadPool 建立一个线程池,它的核心线程数量是固定的,而非核心线程数是没有限制的,而且当非核心线程闲置时会被当即回收,它可安排给定延迟后运行命令或者按期地执行。这类线程池主要用于执行定时任务和具备固定周期的重复任务。
延迟执行实例代码:
public class PoolExecutorTest {
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
//设置池中核心数量是2
ScheduledExecutorService mScheduledThreadPool = Executors.newScheduledThreadPool(2);
System.out.println("如今的时间:"+System.currentTimeMillis());
mScheduledThreadPool.schedule(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("如今的时间:"+System.currentTimeMillis());
}
}, 4, TimeUnit.SECONDS);//这里设置延迟4秒执行
}
}
执行的结果以下:
偏差能够忽略,实际结果确实延迟了4秒执行。
按期执行示例代码
public class PoolExecutorTest {
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
//设置池中核心数量是2
ScheduledExecutorService mScheduledThreadPool = Executors.newScheduledThreadPool(2);
System.out.println("如今的时间:"+System.currentTimeMillis());
mScheduledThreadPool.scheduleAtFixedRate(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("如今的时间:"+System.currentTimeMillis());
}
}, 2, 3,TimeUnit.SECONDS);//这里设置延迟2秒后每3秒执行一次
}
}
执行的结果以下:
可发现确实延迟2秒后每隔3秒后就会执行一次,程序不退出就一直执行下去。
4.newSingleThreadExecutor这类线程池内部只有一个核心线程,以无界队列方式来执行该线程,这使得这些任务之间不须要处理线程同步的问题,它确保全部的任务都在同一个线程中按顺序中执行,而且能够在任意给定的时间不会有多个线程是活动的。
示例代码:
public class PoolExecutorTest {
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
ExecutorService mSingleThreadPool = Executors.newSingleThreadExecutor();
for(int i = 0;i < 7;i++) {
final int number = i;
mSingleThreadPool.execute(new Runnable() {
@Override
public void run() {
System.out.println("如今的时间:"+System.currentTimeMillis()+"第"+number+"个线程");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
}
执行的结果以下:
可发现是有顺序地去执行上面6个线程。
3.使用线程池的优势
1.重用线程池的线程,避免由于线程的建立和销毁锁带来的性能开销
2.有效控制线程池的最大并发数,避免大量的线程之间因抢占系统资源而阻塞
3.可以对线程进行简单的管理,并提供一下特定的操做如:能够提供定时、按期、单线程、并发数控制等功能
————————————————
版权声明:本文为CSDN博主「真·深红骑士」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处连接及本声明。
原文连接:https://blog.csdn.net/qq_33453910/article/details/81413285
相关文章
1.
线程池:第二章:线程池实际中使用哪个
2.
线程池(六)线程池实际使用哪一个
3.
线程池使用
4.
使用线程池
5.
程序员平时上哪些网站
6.
线程池常用的阻塞队列有哪些?
7.
java中的线程池有哪些,分别有什么做用?
8.
何时手动建立线程而不使用线程池
9.
Java 进程中哪些线程占用了大量 CPU 处理时间
10.
线程、线程等待、线程定时器、线程池的使用
更多相关文章...
•
TortoiseSVN 使用教程
-
SVN 教程
•
C# 多线程
-
C#教程
•
Git可视化极简易教程 — Git GUI使用方法
•
Composer 安装与使用
相关标签/搜索
哪些
线程池
Java线程池
使用教程
Java线程池01
平时
使用
用了
offer去哪了
Hibernate教程
Spring教程
PHP教程
教程
应用
学习路线
0
分享到微博
分享到微信
分享到QQ
每日一句
每一个你不满意的现在,都有一个你没有努力的曾经。
最新文章
1.
排序-堆排序(heapSort)
2.
堆排序(heapSort)
3.
堆排序(HEAPSORT)
4.
SafetyNet简要梳理
5.
中年转行,拥抱互联网(上)
6.
SourceInsight4.0鼠标单击变量 整个文件一样的关键字高亮
7.
游戏建模和室内设计那个未来更有前景?
8.
cloudlet_使用Search Cloudlet为您的搜索添加种类
9.
蓝海创意云丨这3条小建议让编剧大大提高工作效率!
10.
flash动画制作修改教程及超实用的小技巧分享,硕思闪客精灵
本站公众号
欢迎关注本站公众号,获取更多信息
相关文章
1.
线程池:第二章:线程池实际中使用哪个
2.
线程池(六)线程池实际使用哪一个
3.
线程池使用
4.
使用线程池
5.
程序员平时上哪些网站
6.
线程池常用的阻塞队列有哪些?
7.
java中的线程池有哪些,分别有什么做用?
8.
何时手动建立线程而不使用线程池
9.
Java 进程中哪些线程占用了大量 CPU 处理时间
10.
线程、线程等待、线程定时器、线程池的使用
>>更多相关文章<<