当前位置:网站首页>过大数组导致爆栈的解决方法记录(堆栈)
过大数组导致爆栈的解决方法记录(堆栈)
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<>,进行动态内存分配。
边栏推荐
猜你喜欢

LeetCode 94. Inorder Traversal of Binary Trees (Simple)

链表API设计

Notes for RNN

Pytorch - 07. Multidimensional characteristics of input processing

2022李宏毅机器学习hw1--COVID-19 Cases Prediction

pytorch-10.卷积神经网络

STM32单片机OLED俄罗斯方块单片机小游戏

机器学习——聚类——商场客户聚类

以STM32F103C6T6为例通过配置CubeMX实现EXIT外部中断

pytorch-06. Logistic regression
随机推荐
详解 Hough 变换(下)圆形检测
LeetCode 162.寻找峰值(中等)
机器学习——聚类——商场客户聚类
pytorch-10.卷积神经网络
51单片机智能蓝牙APP加油站火灾预警安防防控报警监控系统MQ2DHT11
【简易笔记】PyTorch官方教程简易笔记 EP1
分享一款恋爱星座男女配对微信小程序源码
STM32单片机OLED经典2048游戏单片机小游戏
常用模块封装-pymysql、pymongo(可优化)
[Difference between el and template]
我不喜欢我的代码
深度学习阶段性报告(一)
PyTorch 之 可视化网络架构
The submenu of the el-cascader cascade selector is double-clicked to display the selected content
STM32F407ZG PWM
自定义View的流程总结学习
符号表
pytorch-10. Convolutional Neural Networks (homework)
PyTorch的安装与基础知识
The Principle of Union Search and API Design