线程池原理--总索引

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011676300/article/details/83045405

线程池原理–总索引

执行器Executor

拒绝策略

任务队列BlockingQueue

在不使用线程池的时候,我们都是手动创建一个线程并启动。


public MyThread extends Thread{
	public void run(){
		//do something
		.....
	}
	public static void main(String[] args){
		MyThread thread =  new MyThread();
		thread.start();
	}
}

因为创建线程和销毁线程会消耗系统的资源,并不是一种很好的方式去实现多线程,使用线程池比较好。

package com.jt.thread.demo05;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

class MyRunnable implements Runnable {
    @Override
    public void run() {
        for (int x = 0; x < 100; x++) {
            System.out.println(Thread.currentThread().getName() + ":" + x);
       }
    }
}

public class ExecutorServiceDemo {
    public static void main(String[] args) {
     // 创建一个线程池对象,控制要创建几个线程对象。
     // public static ExecutorService newFixedThreadPool(int nThreads)
     ExecutorService pool = Executors.newFixedThreadPool(2);

     // 可以执行Runnable对象或者Callable对象代表的线程
     pool.submit(new MyRunnable());
     pool.submit(new MyRunnable());

    //结束线程池
    pool.shutdown();
   }
}

使用线程池的好处:

  • 第一:降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造成的消耗。

  • 第二:提高响应速度。当任务到达时,任务可以不需要等到线程创建就能立即执行。

  • 第三:提高线程的可管理性。线程是稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统一的分配,调优和监控。**

猜你喜欢

转载自blog.csdn.net/u011676300/article/details/83045405