首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么shrink_to_fit没有约束力?

为什么shrink_to_fit没有约束力?
EN

Stack Overflow用户
提问于 2010-04-18 21:31:29
回答 3查看 2.2K关注 0票数 17

C++0x FCD以23.3.6.2矢量容量表示:

void shrink_to_fit();

备注: shrink_to_fit是一个非绑定请求,用于将容量()减少到size()。注意:请求是不具有约束力的,允许为特定于实现的优化提供空间。-end注记

打算允许什么样的优化?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-04-18 21:46:01

这是一个相当紧张的问题,但是:

考虑向量的分配器,它只能用4KB的粒度分配内存。如果向量的容量为4096,大小为4095,那么重新分配内存就没有意义了,因为这样既不会节省内存,又会浪费一些CPU时间来复制元素。

票数 14
EN

Stack Overflow用户

发布于 2010-04-19 15:12:56

四舍五入的想法确实是相关的,但相当间接的。问题是“允许什么优化”。这是对标准化过程wrt的一些假设。优化。一般来说,目的是允许所有不可观测的优化,然后是一些--例如复制省略--复制ctor的不调用是可观察的。在这种情况下,capacity() != size()可能是优化的一个可观察的效果,并且标准允许它。

至于增加这一自由度的原因,我也可以想象,当capacity()只占size()的101%时,我会忽略收缩请求--收益太少了。永远不会有一个确切的原因,因为LWG由许多持多种观点的人组成。有足够的共识认为,给予这种自由创造了足够多的优化机会。

票数 6
EN

Stack Overflow用户

发布于 2010-04-24 10:58:38

虽然矢量已经很特殊,但它必须以大小为8的块分配,我也知道有些人正在努力使malloc返回任何已分配块的“真实大小”,因此,如果分配的块会带来不可避免的浪费,则向量可以有效地使用空间。

当我们移动到64位OSes时,内存空间突然变得比任何人都接近填充时(著名的遗言)大,因此分配大量的虚拟内存并在任何时候填满它们都变得更加合理。移动物体是昂贵的,在实践中是浪费时间,因为我们没有移动东西,因为物理内存是有限的,只是从一个虚拟的地方到另一个地方!

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2664051

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档