美文网首页
JAVA并发包与线程池

JAVA并发包与线程池

作者: c_gentle | 来源:发表于2021-04-23 18:09 被阅读0次

并发工具包-Concurrent

JDK1.5以后为我们专门提供了一个并发工具包java.util.concurrent。
java.util.concurrent 包含许多线程安全、测试良好、高性能的并发构建块。创建 concurrent 的目的就是要实现 Collection 框架对数据结构所执行的并发操作。通过提供一组可靠的、高性能并发构建块,开发人员可以提高并发类的线程安全、可伸缩性、性能、可读性和可靠性,
并发是伴随着多核处理器的诞生而产生的,为了充分利用硬件资源,诞生了多线程技术。但是多线程又存在资源竞争的问题,引发了同步和互斥的问题,JDK1.5推出的java.util.concurrent(并发工具包)来解决这些问题。

new Thread的弊端

new Thread()新建对象,性能差
线程缺乏统一管理,可能无限制的新建线程,相互竞争,严重时会占用过多系统资源导致死机或OOM

ThreadPool - 线程池

重用存在的线程,减少对象对象、消亡的开销
线程总数可控,提高资源的利用率
避免过多资源竞争,避免阻塞
提供额外功能,定时执行、定期执行、监控等。

线程池的种类

在java.util.concurrent中,提供了工具类Executors(调
度器)对象来创建线程池,可创建的线程池有四种:

  1. CachedThreadPool - 可缓存线程池
  2. FixedThreadPool - 定长线程池
  3. SingleThreadExecutor - 单线程池
  4. ScheduledThreadPool - 调度线程池

CachedThreadPool

package com.caiweiwei.lianxi.controller;

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

public class ThreadPoolSample1 {
    public static void main(String[] args) {
        ExecutorService threadPool= Executors.newCachedThreadPool();//创建一个可缓存线程池
        //可缓存线程池的特点是,无限大,如果线程池中没有可用的线程则创建,有空闲线程则利用起来
        for (int i=0;i<=100;i++){
            int index=i;
            threadPool.execute(new Runnable() {
                @Override
                public void run() {
                    System.out.println(Thread.currentThread().getName()+":"+index);
                }
            });
        }
        try{
            Thread.sleep(1000);//主线程足够的运行时间
        }catch (Exception e){
            e.printStackTrace();
        }
        //shutdown() 代表关闭线程池(等待所有线程完成)
        //shutdownNow() 代表立即终止线程池的运行,不等待线程,不推荐使用
        threadPool.shutdown();
    }
}

FixedThreadPool

package com.caiweiwei.lianxi.controller;

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

public class ThreadPoolSample2 {
    public static void main(String[] args) {
        //ExecutorService用于管理线程池
        ExecutorService executorService = Executors.newFixedThreadPool(3);
        //创建一个可创建一个定长线程池
        //定长线程池的特点是固定线程总数,空间线程用于执行任务,如果线程都在使用后续任务则处于等待状态,在线程池中的线程
        //如果任务处于等待的状态,备选的等待算法默认为FIFO(先进先出) LIFO(后进先出)
        //执行任务后再执行后续的任务。
        for (int i = 0; i < 1000; i++) {
            int index = i;
            executorService.execute(new Runnable() {
                @Override
                public void run() {
                    System.out.println(Thread.currentThread().getName()+":"+index);
                }
            });
        }
        try {
            Thread.sleep(1000);
        }catch (Exception e){
            e.printStackTrace();
        }
        //shutdown() 代表关闭线程池(等待所有线程完成)
        //shutdownNow() 代表立即终止线程池的运行,不等待线程,不推荐使用
        executorService.shutdown();
    }
}

SingleThreadExecutor

package com.caiweiwei.lianxi.controller;

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

public class ThreadPoolSample3 {
    public static void main(String[] args) {
        ExecutorService threadPool = Executors.newSingleThreadExecutor();//单线程线程池
        for (int i = 0; i < 1000; i++) {
            int index = i;
            threadPool.execute(new Runnable() {
                @Override
                public void run() {
                    System.out.println(Thread.currentThread().getName() + ":" + index);
                }
            });
        }
            try{
                Thread.sleep(1000);
            }catch (Exception e){
                e.printStackTrace();
            }
            //shutdown() 代表关闭线程池(等待所有线程完成)
            //shutdownNow() 代表立即终止线程池的运行,不等待线程,不推荐使用
            threadPool.shutdown();

        }
    }


ScheduledThreadPool

package com.caiweiwei.lianxi.controller;

import java.util.Date;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

public class ThreadPoolSample4 {
    public static void main(String[] args) {
        ScheduledExecutorService scheduledExecutorService= Executors.newScheduledThreadPool(5);//可调度线程池
         /*//延迟三秒执行一次Run方法
        scheduledThreadPool.schedule(new Runnable() {
            @Override
            public void run() {
                System.out.println("延迟3秒执行");
            }
        } , 3 , TimeUnit.SECONDS);*/
        //Timer , 项目实际开发中scheduledThreadPool与Timer都不会用到,应为有成熟的调度框架Quartz,或者Spring自带调度,
        //程序的调度框架支持一种表达式叫做Cron表达式,有兴趣的童鞋可以了解一下。
        scheduledExecutorService.scheduleAtFixedRate(new Runnable() {
            @Override
            public void run() {
                System.out.println(new Date() + "延迟1秒执行,每三秒执行一次");
            }
        }, 1, 3, TimeUnit.SECONDS);
    }
    }


相关文章

  • Java多线程--JDK并发包(2)

    Java多线程--JDK并发包(2) 线程池 在使用线程池后,创建线程变成了从线程池里获得空闲线程,关闭线程变成了...

  • java 线程池配置

    简单记录下,配置线程池的时候,各个参数的具体作用 Java util并发包中的线程池配置 简述 一个真正的线程池配...

  • fescar源码分析-NamedThreadFactory

    在java的并发包中java.util.concurrent已经有很多线程池的实现,所有线程池的实现都实现于jav...

  • JAVA并发包与线程池

    并发工具包-Concurrent JDK1.5以后为我们专门提供了一个并发工具包java.util.concurr...

  • 线程池简介

    自JDK1.5,Java吊炸天的并发包就提供线程池java.util.concurrent.ThreadPoolE...

  • JDK并发包——线程池

    title: JDK并发包——线程池date: 2017-04-16 19:05:56tags: Java 并发c...

  • 常用面试题目

    java基础:1.JVM内存模型2.juc并发包线程池,容器,线程安全3.static,final作用域、作用4....

  • java线程池

    线程池能够帮助我们提高系统资源利用效率,并简化线程管理。通过并发包下的Executors(不是Executor)可...

  • springboot线程池创建及使用

    springboot启动类(Application.java)中配置线程池大小 使用类中注入线程池并使用

  • Java线程池

    Java并发包里提供的线程池相关工具类中,最核心的是ThreadPoolExecutor,它强调的是Executo...

网友评论

      本文标题:JAVA并发包与线程池

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