3

只是为了定位上下文:它是关于一个字符串池,意思是一个带有字符串键的哈希表(实际上是知道它们长度的特殊字符串,但我想这个细节在这里无关紧要)。关键是当池需要增长时调整列表数组(用作表桶)的大小。但是——这是核心细节——包含字符串的单元实际上是在一个单元数组中,而不是分散在内存的各个角落 [1]。因此,我不再需要这些列表,它们只是过时的东西。所以:

  1. 是否有一种 realloc 变体可以像 calloc 一样将内存区域“归零”?我在这里需要它,因为这些项目不仅是指针,而且列出了头:问题是确保一个空列表是/显示为 NULL。否则,是最好的解决方案memset(p, size, 0);

  2. 如果没有足够的空间来就地增长,是否有一种不会复制的 realloc 变体,而是像 alloc 一样分配?这里的问题是我不再需要数据,因为字符串需要根据新的模数重新分布在列表中。否则,最好的选择是什么?

    • 使用重新分配
    • (free &) 使用 alloc
    • (免费 &) 使用 calloc

这在任何情况下都是正确的:realloc 尝试在原地分配更多空间,否则在其他地方分配并静默复制?如果是,那么问题可能是(至少)三个用例需要不同的操作——在有或没有足够空间的两种情况下——但是一个没有选项的函数:

  • 我需要更多的地方来存放这些数据以及更多(标准)。
  • 我需要更多的地方,但从现在开始数据就是垃圾。
  • 我需要更多空间和要“归零”的区域。

对我来说最好的选择是什么?你还有什么看法?我在哪里可以找到有关该主题的更多反思或信息?

alloc 与 calloc 和 realloc 有不同的接口是否有原因?(我的意思是指定总尺寸与单一尺寸和计数)

[1] 原来是为了做有序集合&地图;对于字符串池,它不需要但不会打扰。相反,它使代码更清晰并提供了引用的局部性。

4

2 回答 2

4

是否有一种 realloc 变体可以像 calloc 一样将内存区域“归零”?

不。

如果没有足够的空间来就地增长,是否有一种不会复制的 realloc 变体,而是像 alloc 一样分配?

不。

如果我是你,我可能会使用freeand calloc。但理想情况下,您希望将系统设计为不经常重新分配,因此各种选项的不同性能特征并不显着。换句话说,请确保您选择的选项无关紧要。

于 2012-12-12T17:36:45.307 回答
1

是否有一种 realloc 变体可以像 calloc 一样将内存区域“归零”?我在这里需要它,因为这些项目不仅是指针,而且列出了头:问题是确保一个空列表是/显示为 NULL。否则,是 memset(p, size, 0); 的最佳解决方案;

如果您严格按照标准进行编码,那么您将被困在memset. 至少这个很容易解决。

如果您有一些特定于平台的余地,其中一些确实具有recalloc功能。

如果没有足够的空间来就地增长,是否有一种不会复制的 realloc 变体,而是像 alloc 一样分配?这里的问题是我不再需要数据,因为字符串需要根据新的模数重新分布在列表中。否则,最好的选择是什么?

再次不,不幸的是。

有一个C1X 提案,它添加了这两个特性(以及其他特性),但现在你被realloc's 当前行为所困扰。

于 2012-12-12T19:27:06.913 回答