为什么释放速度慢?
我有一个问题,无法在网上找到答案...
我有一个这样声明的集合:
set<unsigned int> MySet
我正在插入用 mersenne twiner 生成的一百万个随机数。随机生成和插入确实很快(一百万个数字大约需要一秒),但释放却非常慢(一分半钟)。
为什么释放这么慢?我没有为该集合使用任何自定义析构函数。
I have a question for which I am unable to find answer on the net...
I have a set declared like this:
set<unsigned int> MySet
I am inserting a million random numbers generated with mersenne twister. Random generation and insertion are really fast (around a second for a million numbers), but deallocation is extremely slow (1 and a half minute).
Why is deallocation so slow? I am not using any custom destructors for the set.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
在发布模式下编译代码。
这有两件事。
该库的调试版本是为了允许调试而构建的,并且它们维护额外的信息(例如标记已解除分配的内存)。所有这些额外的处理实际上都会花费
请注意,此信息是关于 DevStudio 的。
Compile your code in release mode.
This does two things.
The debug version of the library are built to allow for debugging and they maintain extra information (like marking de-allocated memory). All this extra processing does actually cost
Note this information is about DevStudio.
可能是因为以取消分配为代价来优化分配更有意义,因为许多应用程序在不取消分配的情况下进行分配,但反之则不然。我自己也看到过类似的模式,在一个混合调用
malloc
和free
的应用程序中(而不是同时分配和取消分配)。我从未编写过堆分配器,所以我不知道是否还有比这更深层次的技术原因。解除分配时,必须找到并合并相邻的空闲块。所以工作是根本不同的。
90 秒 100 万个小
free()
听起来相当慢。我从来没有真正编写过 Windows 程序,所以我不能说这是否异常,但系统应该能够做得更好。问题的解决方案可能只是在程序退出之前跳过释放对象。您可以尝试从
std::allocator
派生自定义分配器unsigned int >
这使得deallocate
成为无操作。Probably because it makes more sense to optimize allocation at the expense of deallocation, because many applications allocate without deallocating, but never vice versa. I've seen a similar pattern myself, in an application that mixed calls to
malloc
andfree
(as opposed to allocating and deallocating all at once).I've never written a heap allocator, so I don't know if there's a deeper technical reason than that. When deallocating, adjacent free blocks must be found and coalesced. So the work is just fundamentally different.
90 seconds for 1 million small
free()
's sounds quite slow. I've never really programmed Windows so I can't say if that's abnormal, but the system should be able to do much better.The solution to your problem may be simply to skip freeing the objects before the program exits. You might try deriving a custom allocator from
std::allocator< unsigned int >
which makesdeallocate
a no-op.