一、堆和栈的区别
1、申请方式不同。
栈由系统自动分配。
堆是自己申请和释放的。
2、申请大小限制不同。
栈顶和栈底是之前预设好的,栈是向栈底扩展,大小固定,可以通过ulimit -a查看,由ulimit -s修改。
堆向高地址扩展,是不连续的内存区域,大小可以灵活调整。
3、申请效率不同。
栈由系统分配,速度快,不会有碎片。
堆由程序员分配,速度慢,且会有碎片。
4、栈空间默认是4M, 堆区一般是 1G - 4G
5、使用方法不同
堆一般是底层用malloc通过 brk() 系统调用从堆分配内存
栈一般就是直接定义,就是分配,简单的esp,ebp指针的移动
二、你觉得堆快一点还是栈快一点?
毫无疑问是栈快一点。
因为操作系统会在底层对栈提供支持,会分配专门的寄存器存放栈的地址,栈的入栈出栈操作也十分简单,并且有专门的指令执行,所以栈的效率比较高也比较快。
而堆的操作是由C/C++函数库提供的,在分配堆内存的时候需要一定的算法寻找合适大小的内存。并且获取堆的内容需要两次访问,第一次访问指针,第二次根据指针保存的地址访问内存,因此堆比较慢。