开发者

Private heap or manage memory self

I know we could take some advantages from creating private heap of Windows especially for frequently allocated and de-allocated small chunks. But I think the normal approach is to allocate a large memory from default h开发者_Go百科eap and manage the allocations and de-allocations ourselves. My question is which way is advantages and disadvantage between those two ways?

Thanks, Max


Some advantages of managing your own heap:

  • You might be able to optimize very specifically for your own allocation needs and improve performance.
  • You may be able to avoid the use of synchronization objects if you know the concurrency rules.
  • A single free can release an entire set of allocations. For example, a short lived process that needs a bunch of small allocations that are freed all at once could carve them out of a larger block, which can be freed with a single call later.

The disadvantages, though, are very big. The added complexity will produce more bugs, more difficult maintenance, and quite possibly poorer performance in the end. I have absolutely no data to support this, but I suspect that more home-grown heap management systems result in worse performance than help it.

Some advantages of using the system's allocations (e.g., HeapAlloc):

  • Less complexity.
  • Reduced risk of concurrency problems in the allocation/freeing.
  • The ability to take advantage of the Low-Fragmentation Heap. This already does a very good job in most cases of handling the small allocations very efficiently.


Allocating larger chunks is commonly done in pool allocators, where the overhead of allocation and deallocation is reduced and locality is increased (as memory is more likely to be consecutive). More information on pool allocators

In many cases, fragmentation is your worst enemy. When you are allocating, keep object sizes consistent or in sizes (power of two is popular, but may be too wasteful). This reduces fragmentation as there are only a few common sizes of memory which are allocated.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜