当前位置:网站首页>过大数组导致爆栈的解决方法记录(堆栈)
过大数组导致爆栈的解决方法记录(堆栈)
2022-08-10 05:35:00 【introversi0n】
问题背景
今天做题的时候用
int a[1000000];
直接分配内存爆栈了,但是在web的在线IDE上没问题,感觉很奇怪,就查了一下关于堆栈内存的相关问题
堆栈介绍
C和C++编译程序所占内存分为这几个部分:
1、栈(stack)——在内存中连续向低内存扩展,一般由编译器自动分配和释放,用于局部变量的内存开辟
2、堆(heap)——一般由程序员手动申请和释放,如果不释放也会在程序结束时自动释放。
3、静态区/全局区(static)——顾名思义,就是存储静态变量和全局变量的位置,程序结束一道被系统释放
4、文字常量区——存放常量字符串
5、程序代码区——存放函数体二进制代码
由栈转堆
发现原来本地的编译器对于栈是有内存限制的,一般情况下都是1~2MB左右,这就导致定义局部变量的时候或者递归过深都会因栈内存不够而引发爆栈。同时编译器也支持更改栈空间,但是支持幅度有限。
栈在内存是连续地向低内存扩展的空间,使用的申请与释放都是由系统自动完成的。其大小在缺省条件下,很多时候都取决于操作系统。如果我们要申请较大的内存空间,应当手动向堆申请空间,堆空间必须是手动申请和手动释放,有如下几种常用办法:
1、如果是纯C语言,可以使用malloc手动分配内存,然后用free释放。
2、如果是C++,则使用new手动从堆申请内存,用delete释放。
3、另外C++,还可以使用STL内置容器,比如vector<>或stack<>,进行动态内存分配。
边栏推荐
猜你喜欢
随机推荐
以STM32F103C6TA为例通过配置CubeMX实现GPIO输出完成点灯实例
pytorch-06. Logistic regression
51单片机室内环境甲醛PM2.5光照温度湿度检测及窗帘加湿消毒控制系统
I don't like my code
中间件-Rocktmq
generic notes()()()
MySQL中MyISAM为什么比InnoDB查询快
51单片机营养液自动配置搅拌系统TDS浓度采集自动加水加营养液
【目标检测】相关指标的引入与解析
A little knowledge point every day
tinymce rich text editor
pytorch-08. Load dataset
pytorch-10.卷积神经网络
卷积神经网络(CNN)实现服装图像分类
[Notes] Collection Framework System Collection
pytorch-11.卷积神经网络(高级篇)
离散数学的学习记录
LruCache与DiskLruCache结合简单实现ImageLoader
STM32F407ZG 看门狗 IWDG & WWDG
作为测试,常用的adb命令