STRDUP(3) | Руководство программиста Linux | STRDUP(3) |
strdup, strndup, strdupa, strndupa - дублирование строки
#include <string.h>
char *strdup(const char *s);
char *strndup(const char *s, size_t n); char *strdupa(const char *s); char *strndupa(const char *s, size_t n);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
strdup():
strndup():
strdupa(), strndupa(): _GNU_SOURCE
Функция strdup() возвращает указатель на новую строку, являющуюся дубликатом строки s. Память под новую строку выделятся с помощью malloc(3) и может быть высвобождены с помощью free(3).
Функция strndup() похожа на предыдущую, но копирует не более n байт. Если s длиннее n, то копируется только n байт и добавляется конечный байт null ('\0').
Функции strdupa() и strndupa() подобны предыдущим, но для выделения буфера используют alloca(3). Эти функции доступны только при использовании GNU GCC и имеют ограничения, описанные в alloca(3).
При успешном выполнении функция strdup() возвращает указатель на копию строки. Она возвращает NULL, если недостаточно памяти и записывает в errno номер ошибки.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
strdup(), strndup(), strdupa(), strndupa() | Безвредность в нитях | MT-Safe |
Функция strdup() соответствует SVr4, 4.3BSD и POSIX.1-2001. strndup() соответствует POSIX.1-2008. strdupa() и strndupa() являются расширениями GNU.
alloca(3), calloc(3), free(3), malloc(3), realloc(3), string(3), wcsdup(3)
2019-03-06 | GNU |