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

相关推荐
跟着珅聪学java2 小时前
spring boot +Elment UI 上传文件教程
java·spring boot·后端·ui·elementui·vue
我命由我123452 小时前
Spring Boot 自定义日志打印(日志级别、logback-spring.xml 文件、自定义日志打印解读)
java·开发语言·jvm·spring boot·spring·java-ee·logback
lilye662 小时前
程序化广告行业(55/89):DMP与DSP对接及数据统计原理剖析
java·服务器·前端
徐小黑ACG3 小时前
GO语言 使用protobuf
开发语言·后端·golang·protobuf
东方佑3 小时前
自动调整PPT文本框内容:防止溢出并智能截断文本
linux·运维·powerpoint
zhougl9964 小时前
html处理Base文件流
linux·前端·html
0白露4 小时前
Apifox Helper 与 Swagger3 区别
开发语言
Tanecious.5 小时前
机器视觉--python基础语法
开发语言·python
泥土编程5 小时前
kubekey -实现懒人一键部署K8S集群
linux·运维
叠叠乐5 小时前
rust Send Sync 以及对象安全和对象不安全
开发语言·安全·rust