java单线程的循环调用_Java 使用线程池执行若干任务

本文介绍了Java中线程池的使用,包括Fixed Thread Pool、Cached Thread Pool、Single Thread Executor、Work Stealing Pool和Scheduled Executor Service等。详细讲解了不同线程池的特性和适用场景,并提供了任务类型(Runnable和Callable)的实例,以及如何通过submit方法提交任务并获取返回值。
摘要由CSDN通过智能技术生成

在执行一系列带有IO操作(例如下载文件),且互不相关的异步任务时,采用多线程可以很极大的提高运行效率。线程池包含了一系列的线程,并且可以管理这些线程。例如:创建线程,销毁线程等。本文将介绍如何使用Java中的线程池执行任务。

1 任务类型

在使用线程池执行任务之前,我们弄清楚什么任务可以被线程池调用。按照任务是否有返回值可以将任务分为两种,分别是实现Runnable的任务类(无参数无返回值)和实现Callable接口的任务类(无参数有返回值)。在打代码时根据需求选择对应的任务类型。

1.1 实现Runnable接口的类

多线程任务类型,首先自然想到的就是实现 Runnable 接口的类,Runnable接口提供了一个抽象方法run,这个方法无参数,无返回值。例如:

Runnable task = newRunnable() {

@Overridepublic voidrun() {

System.out.println("Execute task.");

}

};

或者Java 8 及以上版本更简单的写法:

Runnable task = ()->{

System.out.println("Execute task.");

};

1.2 实现Callable接口的类

于Runnable一样Callable也只有一个抽象方法,不过该抽象方法有返回值。在实现该接口的时候需要制定返回值的类型。例如:

Callable callableTask = ()-> "finished";

2 线程池类型

java.util.concurrent.Executors 提供了一系列静态方法来创建各种线程池。下面例举出了主要的一些线程池及特性,其它未例举线程池的特性可由下面这些推导出来。

2.1 线程数固定的线程池 Fixed Thread Pool

顾名思义,这种类型线程池线程数量是固定的。如果线程数量设置为n,则任何时刻该线程池最多只有n个线程处于运行状态。当线程池中处于饱和运行状态时,再往线程池中提交的任务会被放到执行队列中。如果线程池处于不饱和状态,线程池也会一直存在,直到ExecuteService 的shutdown方法被调用,线程池才会被清除。

//创建线程数量为5的线程池。

ExecutorService executorService = Executors.newFixedThreadPool(5);

2.2

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,可以通过多线程执行for循环来实现并发执行任务的效果。有几种常见的方法可以实现这个目标。 引用中的示例代码使用了ThreadUtil.execAsync()方法来创建并启动子线程,每个子线程执行一次for循环中的任务。这种方式是将每个任务交给线程池执行,主线程与子线程之间没有先后顺序。 引用中的示例代码使用了CountDownLatch来控制主线程等待所有子线程执行完成。在每个子线程任务执行完毕后,都会调用countDownLatch.countDown()来将计数器减1。主线程通过调用countDownLatch.await()方法来阻塞等待,直到计数器减到0,即所有子线程执行完成后才会继续执行。 引用中的示例代码也使用了CountDownLatch来实现主线程等待所有子线程执行完成。在每个子线程任务执行完毕后,都会调用countDownLatch.countDown()来将计数器减1。主线程通过调用countDownLatch.await()方法来阻塞等待,直到计数器减到0,即所有子线程执行完成后才会继续执行。 所以,以上这些方法都可以实现Java线程执行for循环的效果,具体选择哪种方法取决于实际需求和代码结构。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [JAVA线程处理for循环数据](https://blog.csdn.net/m0_50932526/article/details/130204863)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值