Java线程池

1.什么是线程池

线程池就是事先将多个线程放进一个容器中,当我们需要使用的时候不需要new一个而是去线程池中取一个。

2.使用线程池的好处

2.1不使用线程池的缺点(随用随创建的缺点)

线程的创建和启动以及销毁的开销是巨大的。

使用线程池可以在系统启动时就创建并启动线程,这样用户在请求时不会经历过多的线程创建和启动的时间,改善用户体验。

2.2什么是线程

线程是任务调度的基本单位。

2.2.1Java线程的生命周期

 

线程的五个状态:创建、就绪、运行、阻塞、消亡。

a)       创建(new)

当用new创建一个新的线程对象时,该线程处于创建状态。处于创建状态的线程对象是空的,系统不为它分配资源。

b)       就绪(runnable)

线程已经准备就绪,等待CPU为其分配资源。start()即就绪。

c)       运行(running

线程获得CPU资源,正在按顺序执行代码。

d)       阻塞(blocked

因sleep()或wait()或其他线程join()等而使线程暂停执行让出资源进入等待,即阻塞。

sleep()时间结束或被唤醒nontify()或其他线程执行完毕,线程由阻塞状态进入就绪状态。

e)       消亡(dead

线程执行完毕,或被杀死,即进入消亡状态。

2.2.2线程和进程的区别

进程:是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态概念,竞争计算机系统资源的基本单位。

线程:是进程的一个执行单元,是进程内的调度实体。比进程更小的独立运行的基本单位。线程也被称为轻量级进程。

进程是系统资源分配的基本单位,线程是任务调度的基本单位。

开销:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有独立的运行栈和程序计数器(PC),线程之间的切换开销小。

所处环境:在操作系统中能同时运行多个进程(程序);而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)

内存分配方面:系统在运行的时候会为每个进程分配不同的内存空间;而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。

包含关系:没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。

3.线程池的类别

 

运行线程:

ExecutorService提供了submit和execute方法,向其传入runnable对象或FutureTask对象,当线程获得资源(时间片)时即可进入运行状态。

关闭线程池;

ExecutorService提供了shutdown方法可以关闭线程池。

原文地址:https://www.cnblogs.com/zhihow/p/9819898.html