33--一个进程最多可以创建多少个线程?

这个问题是基于Linux系统下的测试,它跟两个因素有关:进程的虚拟内存上限和系统参数限制。

  1. 进程的虚拟内存上限:

创建线程需要分配栈空间,创建的越多,需要分配的栈空间越多,占用的虚拟内存就越多。

  1. 系统参数限制:

会有系统级别的参数来控制整个系统的最大线程个数。

输入 ulimit -a 后:

如上图我们可以知道服务器默认分配给线程的栈空间大小为8M(倒数第五行)。

通过top -H 可以查看当前系统的线程数,如下图:

可以看到线程数为37405(第二行)。

再执行下列代码:

cs 复制代码
#include <stdio.h>
#include <unistd.h>
#include <pthread.h>
#include <stdlib.h>

void *thread(void *arg)
{
    printf("hello\n");
}

int main()
{
    int res=0;
    int count=0;
    pthread_t id;
    while(res==0)
    {
        res=pthread_create(&id,NULL,thread,NULL);
        count++;
        printf("count=%d\n",count);
    }
    exit(0);
}

得到结果如下:

由上图可以看到创建了32755个线程,也就是说,不能再创建了。

因为其受上述两个因素的影响,故将栈空间大小该变一下,

默认情况下,线程栈的大小通常为8MB。在内存允许的前提下,可以通过减小线程栈的大小,来增加可以创建的线程数量。较小的栈将允许更多的线程同时存在。

如果减少到4MB(4096KB),每个线程的栈空间将占用更少的内存,这样可以创建更多线程。但要注意,栈空间过小可能导致某些操作(尤其是递归操作或需要较大栈空间的操作)出错。

将栈大小改为4MB,输入如下命令:

ulimit -s 4096

再次测试,得到还是32755。

然后将线程数设置为100000,在管理员的身份下,输入如下命令:

echo 100000 | sudo tee /proc/sys/kernel/threads-max

同上还是32755。造成这种情况的原因是因为它不只是跟上述两个因素有关,还会受到资源限制、系统配置、系统内存使用情况以及用户级进程数限制等等的影响。故可以继续检查会受到影响的因素,修改调整,可能会有所改变,并进一步分析。(这里就不进一步分析了)

相关推荐
转转技术团队几秒前
MyBatis-Plus踩坑血泪史:那些年我们踩过的坑!
java·面试·mybatis
sg_knight12 分钟前
IntelliJ IDEA 实用插件:GitToolBox 使用指南
java·ide·git·intellij-idea·插件·gittoolbox
青云交21 分钟前
Java 大视界 -- Java 大数据机器学习模型在电商用户画像构建与精准营销中的应用
java·大数据·机器学习·电商·协同过滤·用户画像·精准营销
浅笑离愁123427 分钟前
VI视频输入模块学习
linux·音视频
z***677729 分钟前
Spring EL 表达式的简单介绍和使用
java·后端·spring
gzr_csdn35 分钟前
【报错解决】VMware 嵌套虚拟化问题
linux·容器
机灵猫1 小时前
java锁:从 Mark Word 锁升级到 AQS
java·开发语言
盛世隐者1 小时前
【Linux】好用的命令记录
linux
山卡拉噶2 小时前
在Linux中安装Kdump调试环境
linux·运维·服务器
扶尔魔ocy2 小时前
【QT opencv】手动去噪--网格化获取区域坐标
开发语言·qt·opencv