一个Java虚拟机可以支持多少线程?这因供应商而异吗?按操作系统?其他因素?
当前回答
最大线程数取决于以下因素: 硬件配置,如微处理器,RAM。 操作系统是32位还是64位 run方法内部的代码。如果run方法内的代码很大,那么单个线程对象将有更多的内存需求
其他回答
在摆弄了Charlie的dielikecode类之后,Java线程堆栈大小似乎是您可以创建的线程数量的很大一部分。
设置java线程堆栈大小
例如
java -Xss100k DieLikeADog
但是,Java有Executor接口。我会使用它,你将能够提交数千个可运行的任务,并让Executor处理这些任务与固定数量的线程。
我知道这个问题很老了,但我还是想分享一下我的发现。
我的笔记本电脑能够处理产生25000个线程的程序,所有这些线程以2秒的间隔在MySql数据库中写入一些数据。
我用10,000个线程连续运行这个程序30分钟,然后我的系统也很稳定,我能够做其他正常的操作,如浏览,打开,关闭其他程序等。
当有25,000个线程时,系统速度变慢,但仍保持响应。
当有50,000个线程时,系统立即停止响应,我不得不手动重启系统。
我的系统详细信息如下:
Processor : Intel core 2 duo 2.13 GHz
RAM : 4GB
OS : Windows 7 Home Premium
JDK Version : 1.6
在运行之前,我设置jvm参数-Xmx2048m。
希望能有所帮助。
在阅读了Charlie Martin的文章后,我很好奇堆大小是否会对您可以创建的线程数量产生影响,结果完全让我目瞪口呆。
使用Vista Home Premium SP1上的JDK 1.6.0_11,我执行Charlie的测试应用程序,使用不同的堆大小,在2mb到1024mb之间。
例如,要创建一个2 MB的堆,我将使用参数-Xms2m -Xmx2m调用JVM。
以下是我的结果:
2 mb --> 5744 threads
4 mb --> 5743 threads
8 mb --> 5735 threads
12 mb --> 5724 threads
16 mb --> 5712 threads
24 mb --> 5687 threads
32 mb --> 5662 threads
48 mb --> 5610 threads
64 mb --> 5561 threads
96 mb --> 5457 threads
128 mb --> 5357 threads
192 mb --> 5190 threads
256 mb --> 5014 threads
384 mb --> 4606 threads
512 mb --> 4202 threads
768 mb --> 3388 threads
1024 mb --> 2583 threads
堆大小肯定很重要。但是堆大小和最大线程数之间的关系是反比的。
这很奇怪。
2017年…… DieLikeADog类。
新线程#92459 java.lang.OutOfMemoryError:无法创建新的本机线程
i7 - 7700 16 gb的ram
至少在Mac OS X 10.6 32位上,操作系统有一个限制(2560)。检查这个stackoverflow线程。
推荐文章
- 在流中使用Java 8 foreach循环移动到下一项
- 访问限制:'Application'类型不是API(必需库rt.jar的限制)
- 用Java计算两个日期之间的天数
- 如何配置slf4j-simple
- 在Jar文件中运行类
- 带参数的可运行?
- 自动化invokerrequired代码模式
- 我如何得到一个字符串的前n个字符而不检查大小或出界?
- 我可以在Java中设置enum起始值吗?
- Java中的回调函数
- c#和Java中的泛型有什么不同?和模板在c++ ?
- 在Java中,流相对于循环的优势是什么?
- Jersey在未找到InjectionManagerFactory时停止工作
- 在Java流是peek真的只是调试?
- Recyclerview不调用onCreateViewHolder