openjavas
openjavas
2010-12-16 17:35
浏览 633
已采纳

JVM线程数限制

public class MaxThreadsTest {

    /**
     * @param args
     */
    public static void main(String[] args) {
        while (true) {
            new Thread(new A()).start();
            if(A.eflag.get()){
                return;
            }
        }

    }

}

class A implements Runnable {
    static AtomicInteger counts = new AtomicInteger(0);
    static AtomicBoolean eflag = new AtomicBoolean(false);

    @Override
    public void run() {
        try {
            int x = counts.getAndIncrement();
            if(x%200==0)
                System.out.println("conts: " + A.counts);
            Thread.sleep(30000);
        } catch (InterruptedException e) {
            eflag.set(true);
            e.printStackTrace();
            
        }
    }
}


-Xms16M -Xmx32M -Xss1M -XX:+HeapDumpOnOutOfMemoryError
conts: 1801
Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread


-Xms32M -Xmx64M -Xss1M -XX:+HeapDumpOnOutOfMemoryError
conts: 1801
Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread


//把Xmx设大可以建立的线程数反而变小,这是个很奇怪的事情:
-Xms64M -Xmx128M -Xss1M -XX:+HeapDumpOnOutOfMemoryError
conts: 1601
Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread

//把Xmx设大可以建立的线程数反而变小,这是个很奇怪的事情:
-Xms128M -Xmx256M -Xss1M -XX:+HeapDumpOnOutOfMemoryError
conts: 1601
Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread


//把Xss设小有惊人效果:
-Xms16M -Xmx32M -Xss128K -XX:+HeapDumpOnOutOfMemoryError
conts: 13401
Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread



以上是在eclipse里测试的。

在windows下直接测试有明显不同。
java MaxThreadsTest -Xms16M -Xmx32M -Xss1M
java MaxThreadsTest -Xms64M -Xmx128M -Xss1M
无论怎么设置都在5401后结束。


我对JVM的了解基本为0,所以也分析不出原因。
请大家帮我看看,这是怎么回事,不是说Xmx越大、Xss越小,则线程数越多么?

 

被移到问答区里了,这么低的悬赏,能有人关注吗?

没办法了,就这么点钱啦……………………………………………………………………

 

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • Wang_Cheng_Bing
    Wang_Cheng_Bing 2010-12-17 13:40
    已采纳

    你的操作系统的内存是多少?
    在java中每new一个线程,jvm都是向操作系统请求new一个本地线程,此时操作系统会使用剩余的内存空间来为线程分配内存,而不是使用jvm的内存。这样,当操作系统的可用内存越少,则jvm可用创建的新线程也就越少。

    点赞 评论
  • Wang_Cheng_Bing
    Wang_Cheng_Bing 2010-12-17 11:02

    Xss设置的是每个线程的堆栈大小,所以然..

    点赞 评论
  • Wang_Cheng_Bing
    Wang_Cheng_Bing 2010-12-20 10:49

    线程是轻量级进程,包含内存入口地址,顺序指令,出口地址。(这一段是占操作系统的内存)
    java的线程分配的堆(保存类的实例)栈(保存局部变量以及指向堆实例的引用)(这一段是jvm的内存)

    点赞 评论

相关推荐