java线程池的理解,创建

 

线程池

表示一组正在等待作业并重复使用多次的工作线程组。

在线程池的情况下,创建一组固定大小的线程。来自线程池中的线程被拉出并由服务提供者分配作业。完成作业后,线程再次包含在线程池中。

Java线程池的优点:

线程的创建和销毁是特别浪费性能的过程,如果可以重用相同功能的线程,则会节省很多性能。

提供了更好的性能,因为不需要重新创建新线程,所以节省了时间。

核心工作工作进程存放:

private final HashSet<Worker> workers = new HashSet<Worker>();

工作队列存放:

private final BlockingQueue<Runnable> workQueue;

线程池创建方式:

ExecutorService es = new ThreadPoolExecutor(5, 10, 3000, TimeUnit.MILLISECONDS,
				new ArrayBlockingQueue<Runnable>(5), new RejectedExecutionHandler() {

					@Override
					public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
						System.out.println(new Thread(r).getName() + "线程被拒绝~~~");
					}
				});

		// 执行线程
		for (int i = 0; i < 17; i++) {
			es.execute(new RDemo());
		}
		// 关闭线程池
		es.shutdown();

 线程池ThreadPollExecutor:

 参数意义:

corePoolSize1:核心线程数量

maximumPoolSize2 - 线程池的容量 = 核心线程数量 + 临时线程数量

keepAliveTime3 - 临时线程的存活时间

Unit4 - 时间单位

workQueue5 - 工作队列

handler6拒绝执行助手

线程池特点及执行流程:

1.线程池在创建之初,里面是没有线程的。

2.当过来请求的时候,线程池中就会创建一个线程来处理这个请求。当处理完请求后返还个线程池中。

3.核心线程在线程池中需要限定数量

4.如果所有的核心线程都在使用,那么在来的请求就会放入工作队列中。工作队列是一个阻塞式队列

5.若所有的核心线程都被占用且工作队列已满,则会创建临时线程去处理新的请求。

6.临时线程处理完请求之后并不是立即销毁,而是存活一段时间,如果过了这段时间依然没有新的请求,那么临时线程就被销毁。

Java本身提供的线程池:

创建线程池工具包:Executors

  1. 缓冲线程池:(newCachedThreadPool)

public static ExecutorService newCachedThreadPool() {

        return new ThreadPoolExecutor(0, Integer.MAX_VALUE,

                                      60L, TimeUnit.SECONDS,

                                      new SynchronousQueue<Runnable>());

    }

特点:

  1. 没有核心线程,所有线程都是临时线程
  2. 线程池的容量可以认为是无限的
  3. 每个临时线程的存活时间是1分钟
  4. 工作队列是一个同步队列,只能存储一个元素

总结:

  1. 大池子小队列
  2. 理论上能够处理任意多的请求
  3. 适合于短任务场景:聊天

.混合线程池:(newFixedThreadPool)

public static ExecutorService newFixedThreadPool(int nThreads) {

        return new ThreadPoolExecutor(nThreads, nThreads,

                                      0L, TimeUnit.MILLISECONDS,

                                      new LinkedBlockingQueue<Runnable>());

    }

特点:

  1. 需要指定核心线程数量
  2. 临时线程不存在,只有核心线程
  3. 工作队列是阻塞式链式队列,没有指定容量

总结:

  1. 小池子大队列
  2. 理论上能够存储任意多的请求
  3. 适合长任务场景:文件下载

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值