栈溢出解决

栈溢出解决

递归调用,栈深度。

错误原因: java.lang.StackOverflowError  栈内存溢出

栈溢出 产生于递归调用,循环遍历是不会的,但是循环方法里面产生递归调用, 也会发生栈溢出。

解决办法:设置线程最大调用深度  

-Xss5m 设置最大调用深度

小伙伴,玩个好玩的,最大默认深度:

package jvmTest;

//打印堆的基本内存信息
public class Test02 {
     private static int count;
     public static void count(){
        try {
             count++;
             count(); 
        } catch (Throwable e) {
            System.out.println("最大深度:"+count);
            e.printStackTrace();
        }
     }
     public static void main(String[] args) {
         count();
    }

  }    

结果:

配置下 可以加大深度调用

来个猛烈的~~

运行结果:

 

 6666 好玩不

 

引用\[1\]:在C++中,栈溢出是由于程序使用的栈空间超过了操作系统给程序分配的栈大小所导致的。当我们在程序中声明一个大数组时,比如double a\[1000\]\[1000\],它会占用大量的栈空间,而操作系统一般只给程序分配1M ~ 2M的栈空间。因此,当数组的大小超过了栈空间的限制,就会发生栈溢出的情况。\[1\] 引用\[3\]:为了解决C++中的栈溢出问题,有几种常见的方法。首先,可以将大数组改为使用STL的vector容器来代替。vector在堆上分配内存,而不是在栈上,因此可以避免栈溢出的问题。另外,如果一个函数有很多局部变量,可以考虑将其拆分为多个函数,使用指针和STL来替代数据量大的变量。这样可以减少函数使用的栈空间,避免栈溢出的发生。\[3\] 因此,要解决C++中的栈溢出问题,可以采取以下措施: 1. 将大数组改为使用STL的vector容器来代替。 2. 将一个多局部变量的函数拆分为多个函数,使用指针和STL来替代数据量大的变量。这样可以减少函数使用的栈空间。 通过以上方法,可以有效地避免C++中的栈溢出问题。 #### 引用[.reference_title] - *1* [C++栈溢出的原因及解决方法](https://blog.csdn.net/WukongAKK/article/details/82559827)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [[转]C++ 堆栈溢出的原因以及可行的解决方法](https://blog.csdn.net/weixin_30474613/article/details/97864537)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [C++栈溢出解决方法总结](https://blog.csdn.net/qq_43376782/article/details/122141990)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值