神奇的线程池——妈妈再也不用担心线程的创建销毁太花时间啦

线程池是Java中用于高效管理线程的容器,避免频繁创建和销毁线程带来的开销。常见线程池包括可缓存线程池、定长线程池、周期定长线程池和单线程线程池。ThreadPoolExecutor是线程池的实现类,其构造参数如corePoolSize、maximumPoolSize等决定了线程池的行为。线程池通过工作队列和饱和策略来处理任务,提供灵活性和性能优化。
摘要由CSDN通过智能技术生成

线程池

什么是线程池

线程池(ThreadPool),听起来就非常的有意思哈。乍一看还以为是将线程放在一个池子中,其实啊,还真是这样,也可以简单的理解为一个可以容纳多个线程的容器。
那么,线程池有啥用呢,和线程相比又有什么特别点呢

线程池的的优势

Java中使用线程的话,除了处理用户的请求之外,时间花的最多的地方就在于创建和销毁线程。而对于线程来说,这两个操作又是必须要做的,而用线程池来代替的话,将线程用线程池来储存着,用到的时候既不用进行创建线程,也不用在结束使用后进行销毁,大大地提高了时间效率。
而且另一方面来说,线程中的切换也是一个需要消耗系统资源的地方,用线程池能很好的解决资源不足问题

线程池的分类

常用线程池主要有以下四种类型:
可缓存线程池(CachedThreadPool):也叫作不定长的线程池,主要优势在于灵活,无论多少线程并发也能承载
定长线程池(FixedThreadPool):优势在于能控制最大的线程并发数量,接下来进入的线程都只能排队等候
周期定长线程池(ScheduledThreadPool):与定长线程池类似,但可以以给定时间为周期执行任务
单线程线程池(SingleThreadPool):同一时间只能容纳一个线程进行任务,后续线程将会进行排队等候

线程池的实现

1、缓存线程池的使用案例:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class Main {
   
    public static void main(String[] args) {
   
        ExecutorService es = Executors.newCachedThreadPool();
        es.execute(new Runnable() {
   
            @Override
            public void run() {
   
                System.out.println("执行该代码");
            }
        });
    }
}

2、定长线程池的使用案例:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class Main {
   
    public static void main(String[] args) {
   
        ExecutorService es = Executors.newFixedThreadPool();
        es.execute(new Runnable() {
   
            @Override
            public void run() {
   
                System.out.println(
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值