Linux repositories inspector
GNU
2019-03-06
Aliases: strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strdupa(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndup(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3), strndupa(3)

man-pages-ru

Russian man pages from the Linux Documentation Project

manpages-dev

Manual pages about using GNU/Linux for development

man-pages

Linux kernel and C library user-space interface documentation

ИМЯ

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():
_XOPEN_SOURCE >= 500
|| /* начиная с glibc 2.12: */ _POSIX_C_SOURCE >= 200809L
|| /* в версии glibc <= 2.19: */ _BSD_SOURCE || _SVID_SOURCE
strndup():
Начиная с glibc 2.10:
_POSIX_C_SOURCE >= 200809L
До glibc 2.10:
_GNU_SOURCE
strdupa(), strndupa(): _GNU_SOURCE

ОПИСАНИЕ

Функция strdup() возвращает указатель на новую строку, являющуюся дубликатом строки s. Память под новую строку выделятся с помощью malloc(3) и может быть высвобождены с помощью free(3).
Функция strndup() похожа на предыдущую, но копирует не более n байт. Если s длиннее n, то копируется только n байт и добавляется конечный байт null (\(aq\0\(aq).
Функции strdupa() и strndupa() подобны предыдущим, но для выделения буфера используют alloca(3). Эти функции доступны только при использовании GNU GCC и имеют ограничения, описанные в alloca(3).

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении функция strdup() возвращает указатель на копию строки. Она возвращает NULL, если недостаточно памяти и записывает в errno номер ошибки.

ОШИБКИ

ENOMEM Недостаточно памяти для размещения копии строки.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).
Интерфейс Атрибут Значение
strdup(), strndup(), strdupa(),
strndupa()
Безвредность в нитях MT-Safe

СООТВЕТСТВИЕ СТАНДАРТАМ

Функция strdup() соответствует SVr4, 4.3BSD и POSIX.1-2001. strndup() соответствует POSIX.1-2008. strdupa() и strndupa() являются расширениями GNU.
⇧ Top