在计算机操作系统中,一个进程所能使用的最大内存是有限制的,这个限制在windows系统中是2G,在linux系统中是3G,而一个线程的默认栈大小是1M,所以理论上来说,在windows系统的一个进程中所能支撑的线程的最大数目为2G/1M,也就是2048个,所以当我们在Windows系统中去跑一个进程,让这个进程去fork多个子线程,当线程的数量达到2000个左右时,这个进程就会崩溃,这是因为这两千个线程已经耗尽了此进程的可用内存。
当然2048只是一个理论上的值,实际上,我们肯定不会将一个进程的所有内存都用来分配给线程的栈,所以,这个数目肯定要小于2048个。当我们的业务需求是让进程支撑更高的线程数量时,我们可以通过调低线程的默认栈大小来实现,比如,将默认栈大小由1M调到512K之后,线程最大数目理论上就可以达到4096个。因为进程可支撑的最大线程数目受到进程最大可用内存的限制,所以我们无法通过扩充机器的物理内存来提高这个数目支持,不过当扩充了物理内存之后,机器可支撑的最大线程数会提高。