ASPRINTF(3) | Руководство программиста Linux | ASPRINTF(3) |
asprintf, vasprintf - выводит данные в строку, выделенную в памяти
#define _GNU_SOURCE /* смотрите feature_test_macros(7) */ #include <stdio.h>
int asprintf(char **strp, const char *fmt, ...);
int vasprintf(char **strp, const char *fmt, va_list ap);
Функции asprintf и vasprintf являются аналогами sprintf(3) и vsprintf(3), отличаясь только тем, что они выделяют в памяти строку, достаточную для размещения результата, включая конечный байт null ('\0'), и возвращают указатель на эту строку через первый аргумент. Для высвобождения выделенной памяти указатель должен быть передан функции free(3).
При успешном выполнении эти функции, подобно sprintf(3), возвращают количество выведенных байтов. Если выделить память не удалось или произошла какая-либо другая ошибка, то эти функции возвращают -1. При этом содержимое strp не определено.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
asprintf(), vasprintf() | Безвредность в нитях | MT-Safe locale |
Эти функции являются расширениями GNU, они отсутствуют в C и POSIX. Также они доступны в *BSD. В FreeBSD при ошибке strp присваивается значение NULL.
2019-03-06 | GNU |