命名空间
变体
操作

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

[编辑] 示例

#ifdef __STDC_ALLOC_LIB__
#define __STDC_WANT_LIB_EXT2__ 1
#else
#define _POSIX_C_SOURCE 200809L
#endif
 
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
 
int main(void)
{
    const char *s1 = "String";
    char *s2 = strndup(s1, 2);
    printf("strndup(\"String\", 2) == %s\n", s2);
    free(s2);
}

输出

strndup("String", 2) == St

[编辑] 参见

(动态内存 TR)
分配字符串的副本
(函数) [编辑]
将一定数量的字符从一个字符串复制到另一个字符串
(函数) [编辑]
分配内存
(函数) [编辑]