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方法可以关闭线程池。