strndup
来自 cppreference.cn
< c | experimental | dynamic
定义于头文件 <string.h> |
||
char *strndup( const char *str, size_t size ); |
(动态内存 TR) | |
返回一个指向空终止字节字符串的指针,该字符串包含从 str
指向的字符串复制的最多 size
个字节。如果在前 size
个字节中未遇到空终止符,则将其添加到重复的字符串中。
返回的指针必须传递给 free 以避免内存泄漏。
如果发生错误,则返回空指针,并且可能会设置 errno。
与动态内存 TR 中的所有函数一样,仅当实现定义了 __STDC_ALLOC_LIB__ 并且用户在包含 string.h
之前将 __STDC_WANT_LIB_EXT2__ 定义为整数常量 1 时,才能保证 strndup
可用。
目录 |
[编辑] 参数
str | - | 指向要复制的空终止字节字符串的指针 |
size | - | 从 str 复制的最大字节数 |
[编辑] 返回值
指向新分配的字符串的指针;如果发生错误,则为空指针。
[编辑] 注释
该函数与 POSIX strndup 相同,除了允许(但不是必须)在发生错误时设置 errno。
[编辑] 示例
运行此代码
输出
strndup("String", 2) == St
[编辑] 参见
(动态内存 TR) |
分配字符串的副本 (函数) |
(C11) |
将一定数量的字符从一个字符串复制到另一个字符串 (函数) |
分配内存 (函数) |