zoukankan      html  css  js  c++  java
  • 堆区和栈区的区别

    C++程序内存布局:
     代码区(code area) 程序内存空间
    全局数据区(data area)
    堆区(heap area)
    栈区(stack area)
    一个由C/C++编译的程序占用的内存分为以下几个部分,
    1)全局区(静态区)(static)存放全局变量、静态数据,const常量。程序结束后有系统释放
    2)栈区(stack) 函数运行时分配,函数结束时释放。由编译器自动分配释放 ,存放为运行函数而分配的局部变量、函数参数、返回数据、返回地址等。其操作方式类似于数据结构中的栈。
    3)堆区(heap) 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS(操作系统)回收。分配方式类似于链表。
    4)文字常量区 常量字符串就是放在这里的。 程序结束后由系统释放。
    5)程序代码区存放函数体(类成员函数和全局函数)的二进制代码。
     

    栈区和堆区的区别:
    1)申请方式: 栈区内存由系统自动分配,函数结束时释放;堆区内存由程序员自己申请,并指明大小,用户忘释放时,会造成内存泄露,不过进程结束时会由系统回收。
    2)申请后系统的响应: 只要栈的剩余空间大于所申请的空间,系统将为程序提供内存,否则将报异常提示栈溢出;堆区,空闲链表,分配与回收机制,会产生碎片问题(外部碎片)-->(固定分区存在内部碎片(分配大于实际),可变分区存在外部碎片(太碎无法分配))。
    3)申请大小的限制:栈是1或者2M,可以自己改,但是最大不超过8M;堆,看主机是多少位的,如果是32位,就是4G
    4)申请效率:栈由系统自动分配,速度较快,程序员无法控制;堆是由new分配的内存,一般速度较慢,而且容易导致内存碎片,但是用起来方便!
    5)存储内容:栈,函数调用(返回值,各个参数,局部变量(静态变量不入栈));堆,一般在堆的头部用一个字节存放堆的大小,堆中的具体内容由程序员安排。
    6)存取效率的比较:栈比堆快,Eg :char c[] = /"1234567890/";char *p =/"1234567890/";读取c[1]和p[1],c[1]读取时直接吧字符串中的元素读到寄存器cl中,而p[1]先把指针值读到edx中,再根据edx读取字符,多一次操作。
    7)管理方式不同:栈,数据结构中的栈;堆,链表
    8)生长方向:栈,高到低;堆,低到高
  • 相关阅读:
    .Net 4.5中的HttpClient试用
    在silverlight中使用微软地图
    SQL语句之语法汇总(一)
    如何将google地图中的经纬度值导入ArcMap
    毕业周年季
    SQL语句之语法汇总(二)
    定时出现和消失的层
    实现iFrame自适应高度,原来很简单!
    .Net 中的反射(查看基本类型信息) Part.2
    反射一些文章
  • 原文地址:https://www.cnblogs.com/zlcxbb/p/5752144.html
Copyright © 2011-2022 走看看