Java创建线程数目问题

来源:互联网 发布:西安聚赢网络 编辑:程序博客网 时间:2024/06/06 17:00
一、JVM最大线程数

       能创建的线程数的具体计算公式如下:(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代码里边。
原创粉丝点击