iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java线程池的简单使用方法实例教程
  • 952
分享到

Java线程池的简单使用方法实例教程

2024-04-02 19:04:59 952人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录线程池使用场景? Java线程池使用总结线程池使用场景? java中经常需要用到多线程来处理一些业务,我们非常不建议单纯使用继承Thread或者实现Runnable接口

线程池使用场景?

java中经常需要用到多线程来处理一些业务,我们非常不建议单纯使用继承Thread或者实现Runnable接口的方式来创建线程,那样势必有创建及销毁线程耗费资源、线程上下文切换问题。同时创建过多的线程也可能引发资源耗尽的风险,这个时候引入线程池比较合理,方便线程任务的管理。java中涉及到线程池的相关类均在jdk1.5开始的java.util.concurrent包中,涉及到的几个核心类及接口包括:Executor、Executors、ExecutorService、ThreadPoolExecutor、FutureTask、Callable、Runnable等。

 Java线程池使用

对于资源池的技术,相信大家早就接触过,比如数据库连接池,常见的有c3p0、dbcp等等,而线程也有对应的池子,称为线程池。

Java提供了Executors类来创建一个线程池,如:


public static void main(String[] args) {
    ExecutorService executorService = Executors.newFixedThreadPool(10);
    Thread thread = new Thread(() -> {
        System.out.println("hello world!");
    });
    executorService.execute(thread);
}

通过newFixedThreadPool()方法可以获得一个指定线程数的线程池。

又如:


public static void main(String[] args) {
    ExecutorService executorService = Executors.newSingleThreadExecutor();
    Thread thread = new Thread(() -> {
        System.out.println("hello world!");
    });
    executorService.execute(thread);
}

通过newSingleThreadExecutor()方法可以获得一个线程数为1的线程池。

还有:


public static void main(String[] args) {
    ExecutorService executorService = Executors.newCachedThreadPool();
    Thread thread = new Thread(() -> {
        System.out.println("hello world!");
    });
    executorService.execute(thread);
}

通过newCachedThreadPool()方法可以获得一个根据需要创建线程的线程池,它会根据任务数创建对应数量的线程。

我们发现,通过Executors类能够创建各式各样的线程池,但阿里巴巴Java开发手册并不推荐我们使用Executors类的方式创建线程,而是要自己手动创建:

那如何手动创建线程池呢?


public static void main(String[] args) {
    ThreadPoolExecutor executor = new ThreadPoolExecutor(
            5,
            10,
            5L,
            TimeUnit.SECONDS,
            new ArrayBlockingQueue<>(3),
            Executors.defaultThreadFactory(),
            new ThreadPoolExecutor.CallerRunsPolicy());
    executor.execute(() -> {
        System.out.println("hello world");
    });
}

构造ThreadPoolExecutor对象即可得到一个线程池,但需要指定七个参数,分别如下:

  1. corePoolSize:核心线程数
  2. maximumPoolSize:最大线程数
  3. keepAliveTime:空闲时间
  4. unit:空闲时间单位
  5. workQueue:任务队列
  6. threadFactory:创建线程的工厂
  7. handler:饱和策略

其中核心线程数表示线程池中最核心的线程,它们在任何情况下都不会被回收,而是等待任务的到来,最大线程数是线程池能够创建的最大线程数,空闲时间表示某个非核心线程在等待空闲时间后仍然没有任务执行,该线程便会被回收,创建线程的工厂用于指定创建线程的方式,一般默认即可,饱和策略表示当线程池达到最大线程数后,超出的任务应该如何进行处理。

举一个简单的例子,现在有10个任务等待执行,因为我们的核心线程数为5,所以线程池会先创建5个线程用于执行其中的5个任务,剩下的5个任务会被放入任务队列,而任务队列的容量只有3,所以任务队列只能够放下3个任务,剩下的2个任务无法放入队列,线程池就会创建2个非核心线程用于执行它们,若是此时线程池中的线程数达到了最大线程数,则会触发饱和策略,比如这里的CallerRunsPolicy策略,它将直接丢弃掉新的任务。

总结

到此这篇关于Java线程池的简单使用的文章就介绍到这了,更多相关Java线程池使用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java线程池的简单使用方法实例教程

本文链接: https://www.lsjlt.com/news/137395.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作