1.进程中创建线程的限制

默认情况下,一个线程的栈要预留1M的内存空间,而一个进程中可用的内存空间只有2G,所以理论上一个进程中最多可以开2048个线程,但是内存当然不可能完全拿来作线程的栈,所以实际数目要比这个值要小。

#define MAX_THREADS 50000
#include <Windows.h>
#include <stdio.h>
DWORD WINAPI ThreadProc(LPVOID lpParam)
{
    while(1)
    {
        Sleep(100000);
    }
    return 0;
}
int main() {

DWORD dwThreadId[MAX_THREADS];
    HANDLE hThread[MAX_THREADS];
    void * stack[MAX_THREADS];
    for(int i = 0; i < MAX_THREADS; ++i)
    {

hThread[i] = CreateThread(0,0, ThreadProc, 0, CREATE_SUSPENDED, &dwThreadId[i]);
        if(0 == hThread[i])
        {
            DWORD e = GetLastError();
            if (e == 8)
            {
                printf("Out of Memory!\n",e);
            }
            else
            {
                printf("%d\r\n",e);
            }
            break;

}
        else
        {
            printf("%d:%d\r\n",i,hThread[i]);
        }

}
    ThreadProc(0);
}

程序的运行结果是:

【  】

2.如何突破2000个限制?

你也可以通过连接时修改默认栈大小,将其改的比较小,这样就可以多开一些线程。 如将默认栈的大小改成512K,这样理论上最多就可以开4096个线程。
    即使物理内存再大,一个进程中可以起的线程总要受到2GB这个内存空间的限制。比方说你的机器装了64GB物理内存,但每个进程的内存空间还是4GB,其中用户态可用的还是2GB。

如果是同一台机器内的话,能起多少线程也是受内存限制的。每个线程对象都要站用非页面内存,而非页面内存也是有限的,当非页面内存被耗尽时,也就无法创建线程了。

如果物理内存非常大,同一台机器内可以跑的线程数目的限制值会越来越大。

MSDN原文:

“The number of threads a process can create is limited by the available virtual memory. By default, every thread has one megabyte of stack space. Therefore, you can create at most 2,048 threads. If you reduce the default stack size, you can create more threads. However, your application will have better performance if you create one thread per processor and build queues of requests for which the application maintains the context information. A thread would process all requests in a queue before processing requests in the next queue.”

可以通过修改CreateThread参数来缩小线程栈StackSize,例如(VC)

#define MAX_THREADS 50000
#include <Windows.h>
#include <stdio.h>

DWORD WINAPI ThreadProc(LPVOID lpParam)
{
    while(1)
    {
        Sleep(100000);
    }
    return 0;
}

int main() {

DWORD dwThreadId[MAX_THREADS];
    HANDLE hThread[MAX_THREADS];
    void * stack[MAX_THREADS];
    for(int i = 0; i < MAX_THREADS; ++i)
    {
        hThread[i] = CreateThread(0,512 * 1024, ThreadProc, 0, STACK_SIZE_PARAM_IS_A_RESERVATION | CREATE_SUSPENDED, &dwThreadId[i]);

if(0 == hThread[i])
        {
            DWORD e = GetLastError();
            if (e == 8)
            {
                printf("Out of Memory!\n",e);
            }
            else
            {
                printf("%d\r\n",e);
            }
            break;

}
        else
        {
            printf("%d:%d\r\n",i,hThread[i]);
        }

}
    ThreadProc(0);
}        

注意上面红色带下划线变化的部分!(0==>512 * 1024,加上了STACK_SIZE_PARAM_IS_A_RESERVATION字段)
程序的运行结果是:

【         】
可以开启的线程数增长了一倍!!

服务器端程序设计

如果你的服务器端程序设计成:来一个client连接请求则创建一个线程,那么就会存在2000个限制(在硬件内存和CPU个数一定的情况下)。建议如下:

The "one thread per client" model is well-known not to scale beyond a dozen clients or so. If you're going to be handling more than that many clients simultaneously, you should move to a model where instead of dedicating a thread to a client, you instead allocate an object. (Someday I'll muse on the duality between threads and objects.) Windows provides I/O completion ports and a thread pool to help you convert from a thread-based model to a work-item-based model.

1. Serve many clients with each thread, and use nonblocking I/O and level-triggered readiness notification
2. Serve many clients with each thread, and use nonblocking I/O and readiness change notification
3. Serve many clients with each server thread, and use asynchronous I/O
上面几句哈的核心的思想是:使用异步I/O,和一个线程处理多个客户请求!!

转载于:https://www.cnblogs.com/zhengah/p/5039634.html

一个进程(Process)最多可以生成多少个线程(Thread)相关推荐

  1. 如何查询一个进程下面的线程数(进程和线程区别)

    在平时工作中,经常会听到应用程序的进程和线程的概念,那么它们两个之间究竟有什么关系或不同呢? 一.对比进程和线程 1)两者概念 -  进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程 ...

  2. Python 进程 Process 模块 - Python零基础入门教程

    目录 一.Python 进程 Process 简介 二.Python 进程 Process 模块 三.Python 进程 Process 函数介绍 四.Python 进程 Process 使用 五.P ...

  3. java 进程 线程数量_如何查询一个进程下面的线程数(进程和线程区别)

    在平时工作中,经常会听到应用程序的进程和线程的概念,那么它们两个之间究竟有什么关系或不同呢? 一.对比进程和线程 1)两者概念 -  进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程 ...

  4. 查询一个进程下面的线程及正在运行的线程

    在平时工作中,经常会听到应用程序的进程和线程的概念,那么它们两个之间究竟有什么关系或不同呢? 一.对比进程和线程 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 1 ...

  5. 多线程(thread)+进程(Process)

    一个进程(Process)里面有多个线程(Thread) 总结:注意,线程开启不一定立即执行,由cpu调度执行

  6. Linux 中统计一个进程的线程数

    如果你想看到 Linux 中每个进程的线程数,有以下几种方法可以做到这一点. 方法一: /proc proc 伪文件系统,它驻留在 /proc 目录,这是最简单的方法来查看任何活动进程的线程数. /p ...

  7. 进程process和线程thread应用和区别——Python学习笔记12

    Subprocess subprocess主要是在Python中执行外部的程序和命令.在Python中,我们通过标准库中的subprocess包来fork一个子进程,并运行一个外部的程序. subpr ...

  8. 进程(process)和线程(thread)

    进程(process)和线程(thread) 来源:阮一峰 进程(process)和线程(thread)是操作系统的基本概念,但是它们比较抽象,不容易掌握. 其实做一个很好的类比,就可以把它们解释地清 ...

  9. wc 一个进程结果是2_用开放的wc创建一个Web组件

    wc 一个进程结果是2 Previously in this series we covered what Web Components are and some tools used to crea ...

最新文章

  1. javaweb学习总结(三十)——EL函数库
  2. Exp9 Web安全基础
  3. easyui点击搜索的时候获取不要文本框里面的值的问题
  4. 字符串对比 (STl强制转换字符串)
  5. postgresql 删除触发器_PostgreSQL:我没有带闪,不讲武德
  6. MYSQL--浅析索引
  7. matlab GUI 设计 自学笔记
  8. Go学习笔记(只有链接)
  9. V-5-4 配置Horizon View Server
  10. Java是块级作用域吗_javascirpt如何模仿块级作用域(js高程笔记)
  11. 判断输入框是不是数字_【Excel技巧】老板说,“我只要数字!数字!”
  12. 51中断实验与流水灯protues仿真
  13. 远控免杀从入门到实践 (11) 终结篇
  14. linux驱动调试方法
  15. oracle查看锁表语句、解锁方法
  16. Java项目服务器cpu占用100%解决办法
  17. 7-11 How Long Does It Take(25 分)
  18. org.apache.ibatis.binding.BindingException: Mapper method 'com.hahah.atcrowdfunding.manager.dao.Cert
  19. 解决Could not get a resource from the pool 异常问题
  20. 研读 项目名-LinkMap-normal-x86_64.txt

热门文章

  1. 利用jaxp对xml进行dom解析
  2. 定义字符串 && 字符串数组
  3. sparkTransformation算子
  4. linux之我常用的20条命令( 之三)
  5. 死磕 java同步系列之AQS起篇
  6. CentOS 7部署rsync备份服务器
  7. 回顾Gartner 报告:2010年至2017年那些最酷的存储初创公司去哪儿了
  8. Bulma - 基于 Flexbox 的现代化的 CSS 框架
  9. php数组的几个函数和超全局变量
  10. linux 卸载、安装mysql