`
flychao88
  • 浏览: 743598 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

由不断的创建线程产生的内存错误所想到的

 
阅读更多
public class MultiThreadOOM {
   public static class SleepThread implements Runnable
   public void run(){
          try {
             Thread.sleep(10000000);
          } catch (InterruptedException e) {
             e.printStackTrace();
          }
   } }
   public static void main(String args[]){
       for(int i=0;i<1500;i++){
          new Thread(new SleepThread(),"Thread"+i).start();
          System.out.println("Thread"+i+" created");
       }
} }

 

我们可以看到,运行结果如下:

Thread1125 created
Thread1126 created
Exception in thread "main" java.lang.OutOfMemoryError: unable to create new
native thread
    at java.lang.Thread.start0(Native Method)
    at java.lang.Thread.start(Thread.java:693)
    at geym.zbase.ch7.oom.MultiThreadOOM.main(MultiThreadOOM.java:23)

 

分析问题:

这个异常问题本质原因是我们创建了太多的线程,而能创建的线程数是有限制的,导致了异常的发生。能创建的线程数的具体计算公式如下: 
(MaxProcessMemory - JVMMemory - ReservedOsMemory) / (ThreadStackSize) = Number of threads 
MaxProcessMemory:指的是一个进程的最大内存
JVMMemory             :  JVM内存
ReservedOsMemory:  保留的操作系统内存
ThreadStackSize      :  线程栈的大小

注:在java语言里, 当你创建一个线程的时候,虚拟机会在JVM内存创建一个Thread对象同时创建一个操作系统线程,而这个系统线程的内存用的不是JVMMemory,而是系统中剩下的内存(MaxProcessMemory - JVMMemory - ReservedOsMemory)。 

分享到:
评论
2 楼 greemranqq 2015-12-08  
ivan19861025 写道
请问线程栈的大小怎么看?

XSS 可以设置,jinfo 好像可以看
1 楼 ivan19861025 2015-10-09  
请问线程栈的大小怎么看?

相关推荐

Global site tag (gtag.js) - Google Analytics