【多线程】并发执行指定数量的线程

有时候为了控制并发规模,我们需要对每次启动的线程做个数量上的限制,可以使用Executors.newFixedThreadPool(int)这个方法。

 

例子

一个线程类,运行中休息几秒为了观察现象更为明显

复制代码
package com.nicchagil.study.thread.cnblogs.No01启动固定数量的线程;

import java.util.concurrent.TimeUnit;


public class MyThread extends Thread {

    @Override
    public void run() {
        System.out.println(this.getName());
        
        /* 设置短暂的停止以看效果 */
        try {
            TimeUnit.SECONDS.sleep(3);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

}
View Code
复制代码

 

启动类

复制代码
package com.nicchagil.study.thread.cnblogs.No01启动固定数量的线程;

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

public class Call {

    public static void main(String[] args) {
        /*
         * 并发执行指定数量的线程
         */
        ExecutorService es = Executors.newFixedThreadPool(2);
        for (int i = 0; i < 5; i++) {
            es.execute(new MyThread());
        }
        
        es.shutdown();
    }

}
View Code
复制代码

 

API参考

Executors.newFixedThreadPool(int)

Executor.execute(java.lang.Runnable)

ExecutorService.shutdown()

Java™ Platform, Standard Edition 7

 

posted @   nick_huang  阅读(1156)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
历史上的今天:
2014-08-19 Oracle“不等于号”与Null的情况
点击右上角即可分享
微信分享提示