原文
1,堆分配(GC
或非GC
)总是要求同步
的共享资源
.
2,堆分配(GC
或非GC
)的高速缓存
利用率很差(GC
涉及大量降低利用率
的高速缓存行
).
3,堆分配(gc
或非gc
)永远不是O(1)
.大的分配
需要从有非线性
复杂性的系统
请求内存(sbrk,mmap
等)的syscalls
.
而栈分配
只是加个整数
到指针
(现代
处理器还有特殊的栈优化
,使栈操作/调用/返回
减少到几乎为零).此外,由于栈
是密集使用的资源
,其高速缓存
利用率是巨大
的,并且由于它是线本
资源,所以在高速缓存行上,一般不存在
竞争.
栈分配
的主要缺点是其大小有限
及可能的栈溢出
风险.