man.bsd.lv manual page server

Manual Page Search Parameters

STRDUP(3) Library Functions Manual STRDUP(3)

strdup, strndupsave a copy of a string

library “libc”

#include <string.h>

char *
strdup(const char *str);

char *
strndup(const char *str, size_t len);

The () function allocates sufficient memory for a copy of the string str, does the copy, and returns a pointer to it. The memory is allocated with malloc(3) and should be released with free(3) when no longer needed.

The () function copies at most len characters from the string str always NUL terminating the copied string.

If insufficient memory is available, NULL is returned and errno is set to ENOMEM. Otherwise, the strdup() family of functions return a pointer to the copied string.

free(3), malloc(3), wcsdup(3)

The strdup() function is specified by IEEE Std 1003.1-2001 (“POSIX.1”). The strndup() function is specified by IEEE Std 1003.1-2008 (“POSIX.1”).

The strdup() function first appeared in 4.3BSD-Reno. The strndup() function was added in FreeBSD 7.2.

May 5, 2020 FreeBSD-13.0