string.h

Перейти к навигацииПерейти к поиску
Стандартная библиотека
языка программирования С

string.h — заголовочный файл стандартной библиотеки языка Си, содержащий функции для работы со строками, оканчивающимися на 0, и различными функциями работы с памятью.

Функции, объявленные в string.h, широко используются, так как являясь частью стандартной библиотеки, они гарантированно работают на всех платформах, поддерживающих Си. Кроме этого, строковые функции работают только с набором символов ASCII или его совместимыми расширениями, такими как ISO-8859-1; многобайтовые кодировки такие как UTF-8 будут работать, с отличием, что «длина» строки будет определяться как число байтов, а не число символов Юникода, которым они соответствуют. Несовместимые с ASCII строки обычно обрабатываются кодом описанным в wchar.h.

Большинство функций string.h не производят никакого выделения памяти и контроля границ; эта обязанность целиком возлагается на программиста.

Константы и типы

ИмяПримечания
NULLрасширяется в null pointer; то есть, значение, которое гарантированно не является валидным адресом объекта в памяти.
size_tбеззнаковое целое, имеющее тот же тип, что и результат оператора sizeof.

Функции

ИмяПримечания
void *memcpy(void *dest, const void *src, size_t n);копирует n байт из области памяти src в dest, которые не должны пересекаться, в противном случае результат не определён (возможно как правильное копирование, так и нет)
void *memmove(void *dest, const void *src, size_t n);копирует n байт из области памяти src в dest, которые в отличие от memcpy могут перекрываться
void *memchr(const char *s, char c, size_t n);возвращает указатель на первое вхождение значения c среди первых n байтов s или NULL, если не найдено
int memcmp(const char *s1, const char *s2, size_t n);сравнивает первые n символов в областях памяти
void *memset(char *dest, char value, size_t size);заполняет область памяти одним байтом value
char *strcat(char *dest, const char *src);дописывает строку src в конец dest
char *strncat(char *dest, const char *src, size_t n);дописывает не более n начальных символов строки src (или всю src, если её длина меньше) в конец dest
char *strchr(const char *s, int c);возвращает адрес символа c в строке s, начиная с головы, или NULL, если строка s не содержит символ c
char *strrchr(const char *s, int c);возвращает адрес символа c в строке s, начиная с хвоста, или NULL, если строка s не содержит символ c
int strcmp(const char *s1, const char *s2);лексикографическое сравнение строк (возвращает "0", если строки одинаковые, положительное, если первая строка больше, и отрицательное, если меньше)
int strncmp(const char *s1, const char *s2, size_t n);лексикографическое сравнение первых n байтов строк
int strcoll(const char *s1, const char *s2);лексикографическое сравнение строк с учетом локали collating order
char *strcpy(char *toHere, const char *fromHere);копирует строку из одного места в другое
char *strncpy(char *toHere, const char *fromHere, size_t n);копирует до n байт строки из одного места в другое
char *strerror(int);возвращает строковое представление сообщения об ошибке errno (не потоко-безопасная)
size_t strlen(const char *str);возвращает длину строки
size_t strspn(const char *s, const char *accept);определяет максимальную длину начальной подстроки, состоящей исключительно из байтов, перечисленных в accept
size_t strcspn(const char *s, const char *reject);определяет максимальную длину начальной подстроки, состоящей исключительно из байтов, не перечисленных в reject
char *strpbrk(const char *s, const char *accept);находит первое вхождение любого символа, перечисленного в accept
char *strstr(const char *haystack, const char *needle);находит первое вхождение строки needle в haystack
char *strtok(char *dest, const char *src);преобразует строку в последовательность токенов. Не потоко-безопасная, не реентерабельная.
size_t strxfrm(char *dest, const char *src, size_t n);создает оттранслированную копию строки, такую, что дословное сравнение её (strcmp) будет эквивалентно сравнению с коллатором.

Расширения к ISO C

ИмяПримечанияОпределена в
char *strdup(const char *);создает копию строки и возвращает указатель на неё POSIX; первоначально расширение в BSD
errno_t strcpy_s(char *restrict s1, rsize_t s1max, const char *restrict s2);вариант strcpy с контролем границ ISO/IEC WDTR 24731
void *mempcpy(void *dest, const void *src, size_t n);вариант memcpy с возвратом байта, следующего за последним записанным GNU
void *memccpy(void *dest, const void *src, int c, size_t n);копирует до n байт из одной области памяти в другую (не должны пересекаться), останавливаясь при встрече символа c UNIX 98?
int *strerror_r(int, char *, size_t);возвращает строкое представление кода ошибки errno (потоко-безопасная; небольшая разница в семантике между GNU и XSI/POSIX) GNU, POSIX
size_t strlcpy(char *dest, const char *src, size_t n);вариант strcpy с контролем границ первоначально OpenBSD, теперь также FreeBSD, Solaris, Mac OS X
char *strtok_r(char *, const char *, char **);потоко-безопасная реентерабельная версия strtok POSIX
char *strsignal(int sig);по аналогии с strerror, возвращает строковое представление сигнала sig (не потоко-безопасная) BSDs, Solaris, Linux

Ссылки