堆(heap)和栈(stack)的区别

在 C/C++里面的程序由5个区组成:栈区,堆区,全局区,文字常量区,程序代码区;
(1)栈的地址空间向低地址方向生长,堆的地址空间向高地址方向生长;
生长方向:就是存放变量的地址由大到小还是由小到大;
下面程序是测试栈和堆的生长方向;

#include <iostream>
using namespace std;

int main()
{

    int m=1 , n=2 ,k=3;
    cout << "&m=" << &m << "\n"<<" &n=" << &n <<"\n"<<"&k="<<&k<<endl;
    int * q = new int(1);
    int * p = new int(1);

    cout << "&q=" << q << "\n" << "&p=" << p << endl;
    delete q;
    delete p;   
    return 0;
}

测试结果:
https://img-blog.csdn.net/20170821144757708?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGxkX2h1bmc=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast

(2)堆的内存空间是由程序员申请释放,容易造成内存泄漏(memory leak)
栈的内存空间由系统分配并且释放;
举例:栈的内存分配, 你去一个餐厅吃饭,你只管去吃菜,不管 它怎么去做,也不用去你去收拾;
堆的内存分配, 你要吃饭,你需要自己去买菜,去做,吃完饭,还要自己去收拾。
(3)栈的存取效率较高,程序运行快;堆相对来说较慢;
(4)程序在编译期间对变量和函数的内存分配都在栈上,函数的参数的内存分配也在栈上;
写的比较简陋,更多细节可以查看这篇博客http://blog.csdn.net/hairetz/article/details/4141043

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值