线程池思想概述java
当咱们要使用线程的时候就去建立一个线程时,虽然实现方便,可是会出现问题:若是并发的线程数量不少,而且每一个线程都是执行一个时间很短的任务就结束了,这样频繁建立线程就会大大下降系统的效率,由于频繁建立线程和销毁线程须要时间。服务器
线程池的概念并发
线程池:其实就是一个容纳多个线程的容器,其中的线程能够反复使用,省去了频繁建立线程对象的操做, 无需反复建立线程而消耗过多资源。ide
/工具
合理利用线程池可以带来三个好处:spa
1. 下降资源消耗。减小了建立和销毁线程的次数,每一个工做线程均可以被重复利用,可执行多个任务。线程
2. 提升响应速度。当任务到达时,任务能够不须要的等到线程建立就能当即执行。code
3. 提升线程的可管理性。能够根据系统的承受能力,调整线程池中工做线线程的数目,防止由于消耗过多的内存,而把服务器累趴下(每一个线程须要大约1MB内存,线程开的越多,消耗的内存也就越大,最后死机)。对象
线程池的使用blog
Java里面线程池的顶级接口是 java.util.concurrent.Executor ,可是严格意义上讲 Executor 并非一个线程池,而只是一个执行线程的工具。真正的线程池接口是 java.util.concurrent.ExecutorService
Executors类中有个建立线程池的方法以下:
public static ExecutorService newFixedThreadPool(int nThreads) :返回线程池对象。(建立的是有界线程池,也就是池中的线程个数能够指定最大数量)
获取到了一个线程池ExecutorService 对象,
使用线程池对象的方法以下:
public Future<?> submit(Runnable task) :获取线程池中的某一个线程对象,并执行。Future接口:用来记录线程任务执行完毕后产生的结果。线程池建立与使用。
使用线程池中线程对象的步骤:
1. 建立线程池对象。
2. 建立Runnable接口子类对象。(task)
3. 提交Runnable接口子类对象。(take task)
4. 关闭线程池(通常不作)。
1 package demosummary.threadpool; 2 3 public class MyRunnable implements Runnable{ 4 @Override 5 public void run() { 6 System.out.println("你好,我想要找某某老师教我Java"); 7 try { 8 Thread.sleep(5000);//等待五秒后,等老师过来 9 } catch (InterruptedException e) { 10 e.printStackTrace(); 11 } 12 System.out.println("老师过来了~" + Thread.currentThread().getName()); 13 System.out.println("今天老师教我了一些基础Java,而后让我回去多练习"); 14 } 15 }
1 package demosummary.threadpool; 2 3 import java.util.concurrent.ExecutorService; 4 import java.util.concurrent.Executors; 5 6 public class ThreadPoolTest { 7 public static void main(String[] args) { 8 //先建立一个线程池对象 9 ExecutorService service = Executors.newFixedThreadPool(5); 10 //建立Runnable实例对象 11 MyRunnable mr = new MyRunnable(); 12 13 /** 14 * 本身建立线程对象的方式 15 * Thread t = new Thread(r); 16 * t.start(); ‐‐‐> 调用MyRunnable中的run() 17 */ 18 //从线程池中获取线程对象,而后调用MyRunnable中的run方法 19 service.submit(mr); 20 //再次从线程池中获取线程对象,而后调用其run方法 21 service.submit(mr); 22 service.submit(mr); 23 // 注意:submit方法调用结束后,程序并不终止,而是把线程归还到线程池中(相似共享充电宝),是由于线程池控制了线程的关闭。 24 // 将使用完的线程又归还到了线程池中 25 // service.shutdown(); // 关闭线程池(通常推荐不关闭) 26 } 27 }