`

JVM系列:-Xss调整Stack Space的大小

 
阅读更多

Java程序中,每个线程都有自己的Stack Space。这个Stack Space不是来自Heap的分配。所以Stack Space的大小不会受到-Xmx和-Xms的影响,这2个JVM参数仅仅是影响Heap的大小。

Stack Space用来做方法的递归调用时压入Stack Frame。所以当递归调用太深的时候,就有可能耗尽Stack Space,爆出StackOverflow的错误。Stack Space的大小随着OS,JVM以及环境变量的大小而发生变化。一般说来默认的大小是512K。在64位的系统中,这个Stack Space值会更大。一般说来,Stack Space为128K是够用的。这时你说需要做的就是观察。如果你的程序没有爆出StackOverflow的错误,可以使用-Xss来调整Stack Space的大小为128K。(eg:-Xss128K)

 

package org.thinking.jvm;

public class TestXSS {

    private static long count = 0;
    
    public static void main(String[] args) {
        infinitelyRecursiveMethod(1);

    }
    
    public static void infinitelyRecursiveMethod(long a){
        System.out.println(count++);
        infinitelyRecursiveMethod(a);
    }

}

 通过上面的程序,你可以观察到你的JVM Stack Space是如何耗尽的,以及进入嵌套的层深。

分享到:
评论

相关推荐

    JVM调优总结 Xms -Xmx -Xmn -Xss

    当-Xms与-Xmx相同时,JVM在启动时会分配一个固定大小的堆内存,从而避免了动态调整带来的性能开销。 - **示例**:`java -Xms3550m ...` #### 2. -Xmx(Maximum Heap Size) - **定义**:设置JVM可以使用的最大堆...

    JVM虚拟机面试题汇总

    - `-Xss`: 设置每个线程的堆栈大小。JDK 1.5+每个线程堆栈大小为1M。 #### 三、对象创建和内存溢出 1. **对象创建**: - 检查指令的参数能否在常量池中找到类的符号引用,并确保这个类已经被加载、解析和初始化...

    java常见的几种内存溢出和解决方案.docx

    解决方法是修改程序,避免递归调用次数太多,并通过-Xss 选项设置每个线程的 Stack 大小。 4.内存泄露: 内存泄露是指程序中的一些定时器或线程没有被正确关闭,导致内存泄露。解决方法是实现 ...

    JAVA-OPTS参数设置.docx

    7. -Xss:每个线程的 Stack 大小,建议设置为 128k。 8. -verbose:gc:实时垃圾收集信息。 9. -Xloggc:gc.log:指定垃圾收集日志文件。 10. -XX:+UseParNewGC:缩短 minor 收集的时间。 11. -XX:+...

    记录java.lang.OutOfMemoryErrorJava heap space的情况.docx

    1. 每个线程都有自己的栈空间(Stack),其大小可以通过`-Xss`参数设置。栈的大小直接影响到可以同时运行的线程数量。 2. 方法区(Method Area)或元空间(Metaspace)在Java 8之后替代了永久代,存储类的元数据。 ...

    JVM 38 道面试题及答案.docx

    * -Xss:设置单个线程栈的大小,一般默认为 512K~1024K。 * -XX:MetaSpaceSize:设置元空间大小,一般不需要改动。 JVM 的内存区域和垃圾回收机制是非常重要的,它们直接影响着 Java 程序的性能和稳定性。

    找工作java知识总结

    - `Xss`:设置每个线程的栈大小。 - `XX:NewRatio`:设置年轻代与老年代的比例。 ### 3. Java线程池 Java线程池是一种基于池化概念的技术,可以预先创建一定数量的线程,并将它们放入线程池中等待任务到来。当有...

    理论:第十三章:堆溢出,栈溢出的出现场景以及解决方案.docx

    1. 增大栈空间:可以通过 JVM 参数 -Xss 来调整栈的大小。 2. 改用动态分配,使用堆(heap)而不是栈(stack):可以使用堆来存储大数组或对象,避免栈溢出。 在实际开发中,我们可以通过以下方式来解决堆溢出和栈...

    java内存泄露、溢出检查方法和工具.doc

    当Java应用程序运行时,JVM(Java虚拟机)会为不同部分分配内存,包括堆(Heap)、年轻代(Young Generation)、年老代(Tenured Generation)和栈(Stack)。如果程序在运行过程中无法正确地释放不再使用的内存,就...

    2023最新JVM+多线程面试真题

    - **Stack Overflow Error**:栈溢出,通常由递归深度过大或线程栈大小(Xss)设置过小引起。 - **PermGen Space**(仅在JDK 1.7及更早版本):持久代空间不足,可能因大量类、常量或动态加载导致。 - **Direct ...

    Java 内存结构备忘录1

    Java 内存结构中,还有一个栈区(Stack Area),可通过 -Xss 选项进行配置。该区域存储了所有线程的堆引用、本地引用、程序计数器寄存器、代码缓存以及本地变量。该区域也称为内存模型的本地区(Native Area)。 ...

    Java内存溢出解决办法

    解决方案是优化代码,减少递归或调整栈的大小(通过-Xss设置)。 3. **方法区/永久代溢出**: 方法区用于存储类信息、常量、静态变量等。JDK8之前,这部分内存被称为永久代,容易因类信息过多而溢出。JDK9之后,这...

    了解Java虚拟机JVM的基本结构及JVM的内存溢出方式

    可以通过调整`-Xss`参数设置栈的大小。 3. **方法区/运行时常量池溢出**:当方法区无法再容纳新的类信息或常量时,可能会引发`OutOfMemoryError: PermGen space`(在较早版本的JVM中)或`Metaspace`溢出(在Java 8...

    linux解决Tomcat内存溢出的问题

    解决方法通常是通过调整JVM的启动参数`-Xms`和`-Xmx`来增大堆内存的初始大小和最大大小。例如,设置`JAVA_OPTS="-server -Xms800m -Xmx800m"`。 2. **PermGen/Metaspace溢出**:当类加载过多, PermGen 或 ...

    java OOM内存泄漏原因及解决方法

    Java OOM内存泄漏原因及解决方法 ...Java OOM内存泄漏是Java开发中常见的一种错误,解决这种错误需要了解JVM内存管理机制和垃圾回收器的工作原理,并且需要善于使用内存监控软件和虚拟机参数来调整堆和栈的大小。

    浅谈java内存管理与内存溢出异常

    解决内存溢出的方法通常包括调整JVM内存参数(如-Xms、Xmx、Xss等)、优化代码以减少资源消耗、及时释放不再使用的对象,以及使用内存分析工具来诊断和定位问题。 总的来说,理解Java内存管理与内存溢出异常对于...

    java内存溢出示例(堆溢出、栈溢出)

    根据实际情况调整JVM的内存分配,例如增加-Xms和-Xmx参数设定堆内存大小,或者增加-Xss参数设定栈内存大小。 5. **使用内存分析工具**:例如MAT (Memory Analyzer Tool),可以帮助定位内存泄漏和分析对象生命周期。...

Global site tag (gtag.js) - Google Analytics