JVM到底能运行多少线程

Jvm可以创建多少个线程

测试1.0

public class TEst {
public static void main(String[] args) {
        MyRunnable mr = new MyRunnable();
       for(;;) {
            Thread t = new Thread(mr, "线程个数: ");
            t.start();
        }
}
     
    public class MyRunnable implements Runnable {
    public static int count = 0;
    @Override
    public void run() {
            count += 1;
            System.err.println(Thread.currentThread().getName() + count);
    }
}

失败原因:

线程 属于一次性消耗品,在执行完run ()方法之后线程便会正常结束了,线程结束后便会销毁,不能再次start,只能重新建立新的线程对象。导致线程每次都重新开始。没有尽头。

解决办法:

在MyRunnable中让线程在run()中,一直睡。

测试2.0

public class TEst {

    public static void main(String[] args) {
        for (;;){
            new Thread(new SomeRunnable(),"线程数").start();
        }
    }
}

 public class MyRunnable implements Runnable {
      public static int count = 0;
      private static Object s = new Object();

    @Override
    public void run() {
            count += 1;
            System.err.println("New thread #" + count);
        for (; ; ) {
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                System.err.println(e);
            }
        }
    }
  }

出现线程安全问题:线程个数并不是有序排列的

解决办法:

让其线程同步,加入同步锁以避免在该线程没有完成操作之前,被其他线程的调用, 从而保证了该变量的唯一性和准确性。 即有synchronized关键字修饰的方法。 内置锁会保护整个方法。在调用该方法前,需要获得内置锁,否则就处于阻塞状态。

测试3.0

public class TEst {

    public static void main(String[] args) {
        for (;;){
            new Thread(new SomeRunnable(),"线程数").start();
        }
    }
}

 public class MyRunnable implements Runnable {
      public static int count = 0;
      private static Object s = new Object();

    @Override
    public void run() {
        synchronized (s) {
            count += 1;
            System.err.println("New thread #" + count);
        }
        for (; ; ) {
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                System.err.println(e);
            }
        }
    }
  }
测试成功

在这里插入图片描述

出现:an unrecoverable stack overflow has occurred.发生了无法恢复的堆栈溢出。表示系统的物理内存不足。

结论:jvm在本机可以创建125383左右个线程。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值