Java多线程2:线程池的使用

一、线程池的使用

1、单线程线程池

public class SingleThread {
    public static void main(String[] args) {
        ExecutorServic eexecutor = Executors.newSingleThreadExecutor();
        for (inti = 0; i < 5; i++) {
            final int no = i;
            Runnable runnable = newRunnable() {
                public void run() {
                    System.out.println(no);
                }
            };
            executor.execute(runnable);
        }
        executor.shutdown();
    }
}

2、固定线程数的线程池

public class FixedThreadPool {
    public static void main(String[] args) {
        ExecutorServiceexecutor = Executors.newFixedThreadPool(5);
        for (inti = 0; i < 20; i++) {
            finalintno = i;
            Runnablerunnable = newRunnable() {
                publicvoidrun() {
                    try {
                        System.out.println("In:" + no);
                        Thread.sleep(1000);
                        System.out.println("Out:" + no);
                    } catch(Exceptione) {}
                }
            };
            executor.execute(runnable);
        }
        executor.shutdown();
    }
}

3、定时周期执行指定的任务

public class ScheduledThread {
    public static void main(String[] args) {
        //以固定延迟时间进行执行,本次执行完成后,到达延迟时间才会执行新的任务
        ScheduledExecutorServiceexecutor = Executors.newScheduledThreadPool(1);
        executor.scheduleWithFixedDelay(newPrintThread(1), // 任务名字
        0, // 初始化延时0秒后开始执行
        1, // 每隔1秒执行一次
        TimeUnit.SECONDS // 时间单位
        );
    }
}

二、线程池的好处

1、四个好处

(1)降低资源消耗:降低线程的创建和销毁产生的消耗。

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

(3)提高线程的可管理性:统一分配,调优和监控。

(4)防止服务器过载,形成内存溢出,或CPU耗尽。

2、线程池技术提高程序的性能

多线程技术主要解决处理器单元内多个线程执行的问题,可以显著减少处理器单元的闲置时间,增加处理器单元的吞吐能力。

3、线程池的应用范围

(1)需要大量的线程来完成任务,且完成任务的时间比较短。

(2)对性能要求苛刻的应用。

(3)接收突发性的大量请求,但不至于使服务器因此产生大量的线程应用。

三、线程池的工作机制和原理

1、线程池核心的两个队列:

  • 线程等待池,即线程队列BlockingQueue。
  • 任务处理池,即正在工作的Thread列表。

2、线程池的核心参数:

  • 核心池的大小,即固定大小。
  • 最大处理线程池数,当线程池里面的线程数: 核心池大小 < 线程数 < 最大处理线程池数,会动态创建与回收线程池里面的线程资源(如果当前核心池的线程都在工作,并且还有任务时,会临时增加的线程数
    )。

3、线程池任务拒绝策略

(1)AbortPolicy:直接抛出异常。

(2)CallerRunPolicy:只用调用者所在线程来运行任务。

(3)DiscardOldestPolicy:丢弃队列中的最旧的一个任务,并执行当前任务。

(4)DiscardPolicy:不处理,丢弃掉。

四、注意

1、线程池要在单例模式下使用,否则会产生一堆线程池。

2、线程池大小设置很大,导致请求过载。

3、注意死锁。

猜你喜欢

转载自blog.csdn.net/f59130/article/details/78515163