我的推理是,如果tcmalloc维护了一个每个线程的空闲列表,那么tcmalloc在平均情况下的性能应该非常接近堆栈分配(调整池大小的成本在许多操作中摊销)。
这在实际实践中成立吗?有没有我没想到的降级案例?
发布于 2017-06-20 01:34:16
堆栈分配由单个机器指令组成-更改堆栈指针。很难看到任何其他方案可以达到这种效率。您通常使用堆栈分配和动态分配通过类似malloc的函数(当然有一个函数调用开销)用于不同的目的,所以哪一个是“更快”的问题还没有定论。
https://stackoverflow.com/questions/44636511
复制相似问题