_expand
更改存储区的大小。
void *_expand(
void *memblock,
size_t size
);
参数
memblock
以前分配的内存块的指针。size
新的大小 (以字节为单位)。
返回值
_expand 返回指向分配的存储区的空指针。 _expand,与 realloc不同的是,无法通过移动块更改其大小。 因而,如果有足够的内存扩展,而无需移动块,则_expand 的 memblock 参数与返回值相同。
在操作期间,如果检测到错误,_expand 返回 NULL。 例如,如果 _expand用于缩小存储区,小型块堆或无效的块指针可能检测到失败并返回NULL。
如果无需移动的情况下可用内存不足展开为给定的大小,则函数返回 NULL。 _expand 从不返回展开的范围小于请求的块。 如果失败,errno 指示失败的性质。 有关 errno的更多信息,请参见errno、_doserrno、_sys_errlist 和 _sys_nerr。
返回值指向保证适当地存储任何类型的对象的对齐的存储空间。 请使用 _msize,检查项的新范围。 若要获得指向类型的指针而不是 void,请对返回值进行类型转换。
备注
尝试展开或收缩块,而无需移动其堆位置_expand 函数更改以前分配的存储区域的大小。 memblock 参数指向块的开始位置。 size 参数为新块的字节大小。 块的内容保持不变,大小变为新值和旧值大小的较小者。 memblock 不应是已释放的块。
备注
在 64 位平台上,如果新的大小小于当前范围,_expand 可能不缩小块;特别是,如果,块的大小小于 16K 尺寸并处于低碎片堆分配,_expand保留块不变并返回 memblock。
当应用程序与调试版本的 C 运行时库连接时,_expand 解析为 _expand_dbg。 有关在调试过程中如何托管堆的详细信息,请参阅 The CRT Debug Heap。
此函数验证其参数。 如果 memblock 是 null 指针,函数会调用无效参数处理程序,如 参数验证 所述。 如果允许执行继续,errno设置为EINVAL,并且函数返回NULL。 如果 size 大于 _HEAP_MAXREQ,设置errno 为 ENOMEM,并且函数返回 NULL。
要求
功能 |
必需的标头 |
---|---|
_expand |
<malloc.h> |
有关其他兼容性信息,请参见“简介”中的兼容性。
示例
// crt_expand.c
#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>
int main( void )
{
char *bufchar;
printf( "Allocate a 512 element buffer\n" );
if( (bufchar = (char *)calloc( 512, sizeof( char ) )) == NULL )
exit( 1 );
printf( "Allocated %d bytes at %Fp\n",
_msize( bufchar ), (void *)bufchar );
if( (bufchar = (char *)_expand( bufchar, 1024 )) == NULL )
printf( "Can't expand" );
else
printf( "Expanded block to %d bytes at %Fp\n",
_msize( bufchar ), (void *)bufchar );
// Free memory
free( bufchar );
exit( 0 );
}
.NET Framework 等效项
不适用。若要调用标准 C 函数,请使用 PInvoke。有关更多信息,请参见平台调用示例。