美文网首页
Java多线程2:线程池的使用

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

作者: 唐影若凡 | 来源:发表于2017-02-07 15:00 被阅读0次

    声明:原创文章,转载请注明出处。http://www.jianshu.com/u/e02df63eaa87

    一、线程池的使用

    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、注意死锁。

    相关文章

      网友评论

          本文标题:Java多线程2:线程池的使用

          本文链接:https://www.haomeiwen.com/subject/nhtmittx.html