栈空间和堆空间的区别

栈空间用于存储函数参数和局部变量,所需空间由系统自动分配,回收也由系统管理,无需人工干预;对空间用于存储动态分配的内存块,分配和释放空间均由程序员控制,有可能产生内存泄漏。

栈空间作为一个严格后进先出的数据结构,可用空间永远都是一块连续的区域;对空间在不断分配和释放空间的过程中,可用空间链表频繁更新,造成可用空间逐渐碎片化,每块可用空间都很小。

栈空间的默认大小只有几M的空间,生长方式是向下的,也就是向着内存地址减小的方向消耗空间;堆空间的理论大小与几G的空间,生长方式是向上的,也就是向着内存地址增大的方向消耗空间。

栈空间有计算机底层的支持,压栈和出栈都有专门的指令,效率较高;堆空间通过函数动态获取空间,涉及可用空间链表的扫描和调整以及相邻可用空间的合并等操作,效率相对较低。

你可能感兴趣的:(C++)