_recalloc_dbg
重新分配数组并将其元素初始化为 0(仅限调试版本)。
语法
void *_recalloc_dbg(
void *userData,
size_t num,
size_t size,
int blockType,
const char *filename,
int linenumber
);
参数
userData
指向之前分配的内存块的指针。
number
内存块的请求数量。
size
每个内存块的请求大小(以字节为单位)。
blockType
内存块的请求类型:_CLIENT_BLOCK
或 _NORMAL_BLOCK
。
若要了解分配块类型及其使用方式,请参阅调试堆上的块类型。
filename
指向已请求分配操作的源文件名的指针或 NULL
。
linenumber
请求分配操作所在的源文件中的行数或 NULL
。
仅当已显式调用 _recalloc_dbg
或已定义 _CRTDBG_MAP_ALLOC
预处理器常数时,才可使用 filename
和 linenumber
参数。
返回值
成功完成时,此函数将返回指向重新分配的内存块的用户部分的指针、调用新的处理程序函数,或者返回 NULL
。 有关返回行为的完整说明,请参阅以下“备注”部分。 若要详细了解如何使用新的处理程序函数的,请参阅 _recalloc
函数。
备注
_recalloc_dbg
是 _recalloc
函数的调试版本。 未定义 _DEBUG
时,每个对 _recalloc_dbg
的调用都简化为对 _recalloc
的调用。 _recalloc
和 _recalloc_dbg
都可重新分配基堆中的内存块,但是 _recalloc_dbg
还包含几种调试功能:用于测试泄漏的块的用户部分两侧的缓冲区、用于跟踪特定分配类型的块类型参数,以及用于确定分配请求的源的 filename
/linenumber
信息。
_recalloc_dbg
将按照比请求大小 (number
* size
) 稍多的空间重新分配指定的内存块,这样请求大小可能会大于或小于最初分配的内存块大小。 额外的空间由调试堆管理器用于链接调试内存块,以及为应用程序提供调试标头信息和覆盖缓冲区。 重新分配可能会导致将原始内存块移动到堆中的其他位置,也可能会导致内存块的大小发生变化。 使用值 0xCD 填充该块的用户部分,使用值 0xFD 填充每个覆盖缓冲区。
如果内存分配失败,则 _recalloc_dbg
将 errno
设置为 ENOMEM
;如果所需的内存量(包括之前提到过的开销)超过 EINVAL
,则返回 _HEAP_MAXREQ
。 有关此错误代码和其他错误代码的信息,请参阅 errno
、_doserrno
、_sys_errlist
和 _sys_nerr
。
若要了解如何在基堆的调试版本中分配、初始化和管理内存块,请参阅 CRT 调试堆详细信息。 若要了解标准堆函数与调试版本之间的区别,请参阅堆分配函数的调试版本。
要求
例程 | 必需的标头 |
---|---|
_recalloc_dbg |
<crtdbg.h> |
有关兼容性的详细信息,请参阅 兼容性。
库
仅限 C 运行时库的调试版本。