我 对jvm 创建线程的一些了解

时间:2023-03-08 21:25:26
我 对jvm 创建线程的一些了解

1、jvm 每创建一个线程都会对应产生一个该线程的虚拟机栈,栈大小通过-Xss参数来设置,JDK1.5之后默认为1M

2、JVM创建线程需要内存,但这部分内存不使用堆内存(毕竟JVM虚拟机栈)。对于32位虚拟机,他可以使用的最大内存为4GB,创建虚拟机栈的空间需要从

这4GB减去堆的空间,因此堆越大,能创建的线程数会减少。(虽然堆中会保存一个Thread对象,但是这对象也没多大吧,呵呵)。

3、另一方面,jvm创建线程,并不仅仅是创建虚拟机栈这一个开销。jvm创建一个线程可能会对应一个操作系统线程(这个不一定,但是不是像Python那样那时间片轮转)。使用native方法在操作系统上创建一个新线程,也需要一定的开销。

4、jvm的-Xmx -Xms是设置堆的大小,java Rumtime 的api显示是jvm当前可以空间,一度让我误会还能设置jvm可用的空间大小(毕竟挫)。

5、对于32位的jvm(jdk1.8自带的Hotspot),设置Xmx=Xms=256M时,大约可以创建1150个线程(二分得出),对了线程栈大小设置为1M。

6、目前还有些疑问,对于操作系统内存管理如何和jvm对应理解(毕竟jvm也是一个进程)。jvm虚拟机栈如何管理(猜测是新建线程分一个,反正大小固定,线程结束就回收。)

http://www.oracle.com/technetwork/java/threads-140302.html