动态分配内存是在堆上,直接创建数组是在栈中,虽然都是在内存,但性能还是有点区别的 栈是机器系统提供的数据结构,计算机会在底层对栈提供支持:分配专门的寄存器存放栈的地址,压栈出栈都有专门的指令执行,这就决定了栈的效率比较高。堆则是C/C++函数库提供的,它的机制是很复杂的,例如为了分配一块内存,库函数会按照一定的算法(具体的算法可以参考数据结构/操作系统)在堆内存中搜索可用的足够大小的空间,如果没有足够大小的空间(可能是由于内存碎片太多),就有可能调用系统功能去增加程序数据段的内存空间,这样就有机会分到足够大小的内存,然后进行返回。显然,堆的效率比栈要低得多。 具体到每个场合,两者体现出来的差异又会不同,跟场景复杂度也有很大的关系,栈胜在简洁,堆胜在灵活
C语言里面的栈和堆
最新推荐文章于 2023-09-25 16:10:17 发布