线程池
一、原理和作用
- 如果并发的线程数量很多,并且每个线程都是执行一段很短的任务就结束了,这样会很浪费系统资源。为了避免这种不必要的系统开销,java中引入线程池的内容。
- 线程池其实就是一个容器。ArrayList HashSet LinkedList HashMap
- 当程序第一次启动时,可以创建多个线程,保存(add( new Thread(xxx)))在集合中;当我们想要是用线程的时候,直接从集合中取出(Thread = list.remove(0)取出第一个)一个线程使用;当我们使用完线程,需要把线程归还(list.add(t), linked.addLast(t))给线程池。
- JDK1.5之后内置了线程池。
二、线程池的使用
线程池:JDK1.5之后提供,在java.util.concurrent.Executors:线程池的工厂类,用来生产线程池。调用静态方法static ExecutorService newFixThreadPool(int nThread)。返回值是ExecutorService 的实现类。
java.util.concurrent.ExecutorService//线程池接口,从来从线程池中获取线程,调用start方法,执行线程任务,
sumbit(Runnable task)//提交一个Runnable任务进行执行
void shutdown()//关闭和销毁线程池。
使用实例:
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class DemoThreadPool {
public static void main(String args[]){
//1.获取线程池
ExecutorService es = Executors.newFixedThreadPool(2);
//2.创建Thread(创建类实现Runnable接口)
//3.使用sumbit获取线程。
es.submit(new RunnableImpl());
es.submit(new RunnableImpl());
es.submit(new RunnableImpl());
es.shutdown();//销毁线程池
}
}