线程池

作者: 程序员大耳 | 来源:发表于2020-04-26 14:43 被阅读0次

一、Executor 线程池的体系UML图:

二、Executor 、ExecutorService 、ThreadPoolExecutor 等类的说明

1、线程池: 提供一个线程队列,队列中保存着所有等待状态的线程。避免了创建与销毁的额外开销,提高了响应的速度。

2、线程池的体系结构:

java.util.concurrent.Executor 负责线程的使用和调度的根接口

|--ExecutorService 子接口: 线程池的主要接口

|--ThreadPoolExecutor 线程池的实现类

|--ScheduledExceutorService 子接口: 负责线程的调度

|--ScheduledThreadPoolExecutor : 继承ThreadPoolExecutor,实现了ScheduledExecutorService

3、工具类 : Executors

ExecutorService newFixedThreadPool() : 创建固定大小的线程池

ExecutorService newCachedThreadPool() : 缓存线程池,线程池的数量不固定,可以根据需求自动的更改数量。

ExecutorService newSingleThreadExecutor() : 创建单个线程池。 线程池中只有一个线程

ScheduledExecutorService newScheduledThreadPool() : 创建固定大小的线程,可以延迟或定时的执行任务

三、代码示例:

import java.util.ArrayList;

import java.util.List;

import java.util.concurrent.Callable;

import java.util.concurrent.ExecutionException;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.Future;

public class TestThreadPool {

public static void main(String[] args) throws InterruptedException, ExecutionException {

//1. 创建线程池

ExecutorService pool = Executors.newFixedThreadPool(5);

List<Future<Integer>> list=new ArrayList<Future<Integer>>();

for (int i = 0; i < 10; i++) {

Future<Integer>  future=pool.submit(new Callable<Integer>() {

public Integer call() throws Exception {

int sum=0;

for (int i = 0; i <=100; i++) {

sum+=i;

}

return sum;

}

});

list.add(future);

}

pool.shutdown();

for (Future<Integer> future : list) {

System.out.println(future.get());

}

// Future<Integer>  future=pool.submit(new Callable<Integer>() {

// public Integer call() throws Exception {

// int sum=0;

// for (int i = 0; i <=100; i++) {

// sum+=i;

// }

// return sum;

// }

// });

// System.out.println(future.get());

// pool.shutdown();

// ThreadPoolDemo threadPoolDemo=new ThreadPoolDemo();

//

// //2. 为线程池中的线程分配任务

// for (int i = 0; i < 10; i++) {

// pool.submit(threadPoolDemo);

// }

//

// //3. 关闭线程池

// pool.shutdown();

//

// new Thread(threadPoolDemo).start();

// new Thread(threadPoolDemo).start();

}

}

class ThreadPoolDemo implements Runnable{

private int i=0;

public void run() {

while(i<=100){

System.out.println(Thread.currentThread().getName()+" "+ i++);

}

}

}

四、Java 获得CPU工作核心数

/**

* 根据 Java 虚拟机可用处理器数目返回最佳的线程数。<br>

* 最佳的线程数 = CPU可用核心数 / (1 - 阻塞系数),其中阻塞系数这里设为0.9

*/publicstaticintgetBestPoolSize(){try{// JVM可用处理器的个数finalintcores=Runtime.getRuntime().availableProcessors();// 最佳的线程数 = CPU可用核心数 / (1 - 阻塞系数)// TODO 阻塞系数是不是需要有个setter方法能让使用者自由设置呢?return(int)(cores/(1-0.9));}catch(Throwable e){// 异常发生时姑且返回10个任务线程池return10;}}

相关文章

  • java线程池

    线程VS线程池 普通线程使用 创建线程池 执行任务 执行完毕,释放线程对象 线程池 创建线程池 拿线程池线程去执行...

  • java----线程池

    什么是线程池 为什么要使用线程池 线程池的处理逻辑 如何使用线程池 如何合理配置线程池的大小 结语 什么是线程池 ...

  • Java线程池的使用

    线程类型: 固定线程 cached线程 定时线程 固定线程池使用 cache线程池使用 定时调度线程池使用

  • Spring Boot之ThreadPoolTaskExecut

    初始化线程池 corePoolSize 线程池维护线程的最少数量keepAliveSeconds 线程池维护线程...

  • 线程池

    1.线程池简介 1.1 线程池的概念 线程池就是首先创建一些线程,它们的集合称为线程池。使用线程池可以很好地提高性...

  • 多线程juc线程池

    java_basic juc线程池 创建线程池 handler是线程池拒绝策略 排队策略 线程池状态 RUNNIN...

  • ThreadPoolExecutor线程池原理以及源码分析

    线程池流程: 线程池核心类:ThreadPoolExecutor:普通的线程池ScheduledThreadPoo...

  • 线程池

    线程池 [TOC] 线程池概述 什么是线程池 为什么使用线程池 线程池的优势第一:降低资源消耗。通过重复利用已创建...

  • java 线程池使用和详解

    线程池的使用 构造方法 corePoolSize:线程池维护线程的最少数量 maximumPoolSize:线程池...

  • 线程池

    JDK线程池 为什么要用线程池 线程池为什么这么设计 线程池原理 核心线程是否能被回收 如何回收空闲线程 Tomc...

网友评论

      本文标题:线程池

      本文链接:https://www.haomeiwen.com/subject/rvodwhtx.html