您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
在Java中,可以使用java.util.concurrent.ExecutorService
和java.util.concurrent.Executors
类来创建线程池
Executors
工具类创建线程池:import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExample {
public static void main(String[] args) {
// 创建一个固定大小的线程池,其中包含4个线程
ExecutorService executorService = Executors.newFixedThreadPool(4);
// 提交任务到线程池
for (int i = 0; i < 10; i++) {
executorService.submit(() -> {
System.out.println("Task executed by thread: " + Thread.currentThread().getName());
});
}
// 关闭线程池
executorService.shutdown();
}
}
Executors
工具类创建缓存线程池:import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExample {
public static void main(String[] args) {
// 创建一个可缓存的线程池,当任务数量超过线程池大小时,可重用已创建的线程
ExecutorService executorService = Executors.newCachedThreadPool();
// 提交任务到线程池
for (int i = 0; i < 10; i++) {
executorService.submit(() -> {
System.out.println("Task executed by thread: " + Thread.currentThread().getName());
});
}
// 关闭线程池
executorService.shutdown();
}
}
Executors
工具类创建单线程化的线程池:import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExample {
public static void main(String[] args) {
// 创建一个单线程化的线程池
ExecutorService executorService = Executors.newSingleThreadExecutor();
// 提交任务到线程池
for (int i = 0; i < 10; i++) {
executorService.submit(() -> {
System.out.println("Task executed by thread: " + Thread.currentThread().getName());
});
}
// 关闭线程池
executorService.shutdown();
}
}
注意:在使用完线程池后,请调用shutdown()
或shutdownNow()
方法来关闭线程池。shutdown()
方法将启动线程池的关闭过程,但不会立即停止正在执行的任务。而shutdownNow()
方法将尝试立即停止所有正在执行的任务。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。