STPCPY(3) | Руководство программиста Linux | STPCPY(3) |
stpcpy - копирование строки с возвращением указателя на её конец
#include <string.h>
char *stpcpy(char *dest, const char *src);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
stpcpy():
Функция strcpy() копирует строку, указанную в src, включая завершающий байт null ('\0'), в массив, указанный в dest. Строки не могут перекрываться, а строка назначения dest должна быть достаточно велика, чтобы хранить копию.
Функция stpcpy() возвращает указатель на конец строки dest (то есть адрес конечного байта null), а не на её начало.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
stpcpy() | Безвредность в нитях | MT-Safe |
Эта функция была добавлена в POSIX.1-2008. До этого, она не была частью стандарта C или POSIX.1, или обычной для систем UNIX. Впервые она появилась не раньше 1986 года в компиляторе Lattice C AmigaDOS, затем в GNU fileutils и GNU textutils в 1989 году, и в библиотеке GNU C в 1992 году. Также она есть в разных BSD.
Эта функция может переполнить буфер dest.
Данная программа использует stpcpy() для объединения foo и bar, чтобы получить строку foobar, которая затем выводится.
#define _GNU_SOURCE #include <string.h> #include <stdio.h> int main(void) { char buffer[20]; char *to = buffer; to = stpcpy(to, "foo"); to = stpcpy(to, "bar"); printf("%s\n", buffer); }
bcopy(3), memccpy(3), memcpy(3), memmove(3), stpncpy(3), strcpy(3), string(3), wcpcpy(3)
2019-03-06 | GNU |