_aligned_malloc_dbg
在指定内存边界上为调试标头和覆盖缓冲区分配内存(仅限调试模式)。
void * _aligned_malloc_dbg( size_t size, size_t alignment, const char *filename, int linenumber );
参数
[in] size
请求的内存分配的大小。[in] alignment
对齐值,必须是 2 的整数幂。[in] filename
指向已请求分配操作的源文件名的指针或 NULL。[in] linenumber
请求分配操作所在的源文件中的行数或 NULL。
返回值
指向已分配的内存块的指针或 NULL(如果操作失败)。
备注
_aligned_malloc_dbg 是 _aligned_malloc 函数的调试版本。 未定义 _DEBUG 时,每个对 _aligned_malloc_dbg 的调用都会减少到对 _aligned_malloc 的调用。 _aligned_malloc 和 _aligned_malloc_dbg 都可分配基堆中的内存块,但是 _aligned_malloc_dbg 还提供几种调试功能:用于测试泄漏的块的用户部分两侧的缓冲区,以及用于确定分配请求的源的 filename/linenumber 信息。
_aligned_malloc_dbg 将使用比请求的 size 稍多的空间分配内存块。 其他空间将由调试堆管理器用于链接调试内存块,以及提供具有调试标头信息的应用程序和覆盖缓冲区。 分配该块后,使用值 0xCD 填充该块的用户部分,使用值 0xFD 填充每个覆盖缓冲区。
如果内存分配失败,或者如果所需的内存量(包括之前提到过的开销)超过 _HEAP_MAXREQ,则 _aligned_malloc_dbg 将 errno 设置为 ENOMEM。 有关此错误代码和其他错误代码的信息,请参阅 errno、_doserrno、_sys_errlist 和 _sys_nerr。 此外,_aligned_malloc_dbg 将验证其参数。 如果 alignment 不是 2 的幂或 size 是零,则此函数调用的参数处理程序无效,如参数验证中所述。 如果允许执行继续,则此函数将返回 NULL 并将 errno 设置为 EINVAL。
有关如何在基堆的调试版本中分配、初始化和管理内存块的信息,请参阅 CRT 调试堆详细信息。 有关分配块类型及其使用方式的信息,请参阅调试堆中的块类型。 有关在应用程序的调试版本中调用标准堆函数及其调试版本之间的差异的信息,请参阅堆分配函数的“Debug”版本。
要求
例程 |
必需的标头 |
---|---|
_aligned_malloc_dbg |
<crtdbg.h> |
有关更多兼容性信息,请参见“简介”中的兼容性。
库
仅限 C 运行时库的调试版本。
.NET Framework 等效项
不适用。若要调用标准 C 函数,请使用 PInvoke。有关更多信息,请参见平台调用示例。