1.申请方式不同:
栈:由操作系统自动分配、释放,存放函数参数、局部变量,分配的内存是连续的,类似于数据结构中的栈;
堆:一般情况下由程序员分配和释放,如果程序员不释放,在结束程序时,由操作系统回收,分配的内存是不连续的,类似数据结构中的链表结构;
另外程序占用的内存区还包括:
全局区:由操作系统自动分配和释放。存放全局变量和静态变量;初始化的和未初始化的变量分别存储两个区域;程序结束后系统自动释放
文字常量区:存储常量字符串。程序结束后系统自动释放
程序代码区:存放函数体的二进制代码;
例子:
char c; //变量c是在栈上分配的内存;
char *p = new char[3]; //p是在栈上分配的内存,但是执行new char 命令时,是在堆上分配,只是将数组首地址赋给了p;
C语言中用malloc分配的也是堆上的空间。
2.大小
栈的空间比较小;
堆的空间比较大;
3.申请效率
栈:由系统分配控制,速度快,效率高;
堆:由程序员控制,申请速度慢,并且在使用过程中产生碎片;但使用方便;
浅析-栈与堆的区别
最新推荐文章于 2022-07-19 22:10:03 发布