Java创建线程数目问题
来源:互联网 发布:西安聚赢网络 编辑:程序博客网 时间:2024/06/06 17:00
一、JVM最大线程数
JVMMemory JVM内存
ReservedOsMemory 保留的操作系统内存
ThreadStackSize 线程栈的大小
由公式得出结论:你给JVM内存越多,那么你能创建的线程越少,越容易发生java.lang.OutOfMemoryError: unable to create new native thread。
二、解决问题:
1,如果程序中有bug,导致创建大量不需要的线程或者线程没有及时回收,就必须解决这个bug,修改参数是不能解决问题的。
在java应用中,有时候会出现这样的错误:OutOfMemoryError: unable to create new native thread.这种怪事是因为JVM已经被系统分配了大量的内存(比如1.5G),并且它至少要占用可用内存的一半。有人发现,在线程个数很多的情况下,你分配给JVM的内存越多,那么,上述错误发生的可能性就越大。
在java语言里, 当你创建一个线程的时候,虚拟机会在JVM内存创建一个Thread对象同时创建一个操作系统线程,而这个系统线程的内存用的不是JVMMemory,而是系统中剩下的内存(MaxProcessMemory-JVMMemory-ReservedOsMemory)。
每一个32位的进程最多可以使用2G的可用内存,因为另外2G被操作系统保留。这里假设使用1.5G给JVM,那么还余下500M可用内存。这500M内存中的一部分必须用于系统dll的加载,那么真正剩下的也许只有400M,现在关键的地方出现了:当你使用Java创建一个线程,在JVM的内存里也会创建一个Thread对象,但是同时也会在操作系统里创建一个真正的物理线程(参考JVM规范),操作系统会在余下的400兆内存里创建这个物理线程,而不是在JVM的1500M的内存堆里创建。在jdk1.4里头,默认的栈大小是256KB,但是在jdk1.5里头,默认的栈大小为1M每线程,因此,在余下400M的可用内存里边我们最多也只能创建400个可用线程。
这样结论就出来了,要想创建更多的线程,你必须减少分配给JVM的最大内存。还有一种做法是让JVM宿主在你的JNI代码里边。
能创建的线程数的具体计算公式如下:(MaxProcessMemory-JVMMemory-ReservedOsMemory)/(ThreadStackSize)=Number of threads
MaxProcessMemory 指的是一个进程的最大内存JVMMemory JVM内存
ReservedOsMemory 保留的操作系统内存
ThreadStackSize 线程栈的大小
由公式得出结论:你给JVM内存越多,那么你能创建的线程越少,越容易发生java.lang.OutOfMemoryError: unable to create new native thread。
二、解决问题:
1,如果程序中有bug,导致创建大量不需要的线程或者线程没有及时回收,就必须解决这个bug,修改参数是不能解决问题的。
2,如果程序确实需要大量的线程,现有的设置不能达到要求,那么可以通过修改MaxProcessMemory,JVMMemory,
3、ThreadStackSize这三个因素,来增加能创建的线程数:
a, MaxProcessMemory 使用64位操作系统
b, JVMMemory 减少JVMMemory的分配
c, ThreadStackSize 减小单个线程的栈大小
在java应用中,有时候会出现这样的错误:OutOfMemoryError: unable to create new native thread.这种怪事是因为JVM已经被系统分配了大量的内存(比如1.5G),并且它至少要占用可用内存的一半。有人发现,在线程个数很多的情况下,你分配给JVM的内存越多,那么,上述错误发生的可能性就越大。
在java语言里, 当你创建一个线程的时候,虚拟机会在JVM内存创建一个Thread对象同时创建一个操作系统线程,而这个系统线程的内存用的不是JVMMemory,而是系统中剩下的内存(MaxProcessMemory-JVMMemory-ReservedOsMemory)。
每一个32位的进程最多可以使用2G的可用内存,因为另外2G被操作系统保留。这里假设使用1.5G给JVM,那么还余下500M可用内存。这500M内存中的一部分必须用于系统dll的加载,那么真正剩下的也许只有400M,现在关键的地方出现了:当你使用Java创建一个线程,在JVM的内存里也会创建一个Thread对象,但是同时也会在操作系统里创建一个真正的物理线程(参考JVM规范),操作系统会在余下的400兆内存里创建这个物理线程,而不是在JVM的1500M的内存堆里创建。在jdk1.4里头,默认的栈大小是256KB,但是在jdk1.5里头,默认的栈大小为1M每线程,因此,在余下400M的可用内存里边我们最多也只能创建400个可用线程。
这样结论就出来了,要想创建更多的线程,你必须减少分配给JVM的最大内存。还有一种做法是让JVM宿主在你的JNI代码里边。
- Java创建线程数目问题
- String对象创建数目问题
- java多线程同步及最大线程数目
- 一个进程最多可以创建线程的数目
- 一个进程最多可以创建线程的数目
- 有关Linux进程与线程数目计算的问题
- nginx中关于创建work进程数目问题的心得
- Xen创建虚拟机 loop device 数目限制问题
- java基于AbstractQueuedSynchronizer实现资源共享锁,限制并发线程数目
- 线程 进程最大数目
- 查看线程数目
- Java ThreadPoolExecutor 线程池 tips 1:单线程吞吐量来估计系统的线程数目
- Java ThreadPoolExecutor 线程池 tips 1:单线程吞吐量来估计系统的线程数目
- Java 线程创建
- java创建线程池
- java创建线程池
- Java创建线程
- 创建Java线程池
- 在 Adobe AIR 中为不同屏幕尺寸的多种设备提供支持
- 数据挖掘:同义词的那些事
- JNI 中文字符串转换乱码的处理
- Andorid之Annotation框架初使用(一)
- linux boa服务器
- Java创建线程数目问题
- android 屏蔽home键
- 【COCOS2DX-IOS-游戏开发之二一】之 最热血的RPG+RTS塔防游戏Flesh&Blood-Attack on Orc上线了
- 在 ubuntu下配置时区的方法
- 处理文本文件命令sed
- Eclipse插件开发如何应用另一个项目作为插件
- Android动画效果——X、Y轴抖动
- 用spring实现的发送mail实例
- Emgu 距离变换