Linux repositories inspector
2017-09-15
Aliases: tmpnam_r(3), tmpnam_r(3), tmpnam_r(3), tmpnam_r(3), tmpnam_r(3), tmpnam_r(3), tmpnam_r(3), tmpnam_r(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

ИМЯ

tmpnam, tmpnam_r - создаёт имя для временного файла

ОБЗОР

#include <stdio.h>

char *tmpnam(char *s); char *tmpnam_r(char *s);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
tmpnam_r()
Начиная с glibc 2.19:
_DEFAULT_SOURCE
Начиная с glibc 2.19:
_BSD_SOURCE || _SVID_SOURCE

ОПИСАНИЕ

Замечание: не используйте эти функции; вместо них используйте mkstemp(3) или tmpfile(3).
Функция tmpnam() возвращает указатель на строку, содержащую корректное имя файла, и гарантирует, что файла с таким именем не существует на момент вызова, и наивный программист может считать это имя самым подходящим для временного файла. Если аргумент s равен NULL, это имя генерируется во внутреннем статическом буфере и может быть изменено последующим вызовом tmpnam(). Если s не равно NULL, то имя копируется в массив символов (длиной не менее L_tmpnam), на который указывает s, и в случае успешного выполнения возвращается значение s.
Созданное имя файла содержит префикс каталога P_tmpdir (L_tmpnam и P_tmpdir определены в <stdio.h> также, как TMP_MAX, описанная ниже).
Функция tmpnam_r() выполняет ту же задачу, что и tmpnam(), но возвращает NULL (возникла ошибка), если s равно NULL.

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

Эти функции возвращают указатель на уникальное имя временного файла, либо NULL, если уникальное имя невозможно сгенерировать.

ОШИБКИ

Ошибок не предполагается.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).
Интерфейс Атрибут Значение
tmpnam() Безвредность в нитях MT-Unsafe race:tmpnam/!s
tmpnam_r() Безвредность в нитях MT-Safe

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

tmpnam(): SVr4, 4.3BSD, C89, C99, POSIX.1-2001. В POSIX.1-2008 функция tmpnam() помечена как устаревшая.
Функция tmpnam_r() является нестандартным расширением, но доступна и в некоторых других системах.

ЗАМЕЧАНИЯ

Функция tmpnam() генерирует уникальное имя каждый раз, до TMP_MAX вызовов. Если она будет вызвана более чем TMP_MAX раз, то дальнейшее поведение определяется конкретной реализацией.
Хотя эти функции генерируют имена, которые трудно подобрать, тем не менее, есть вероятность, что за промежуток времени, когда вернётся имя файла и программа откроет его, другая программа успеет создать с помощью open(2) файл с таким же именем или символическую ссылку, что может привести к проблемам с безопасностью. Чтобы исключить подобную вероятность, для открытия файла используйте open(2) с флагом O_EXCL. А ещё лучше — воспользуйтесь mkstemp(3) или tmpfile(3).
Если определён _POSIX_THREADS или _POSIX_THREAD_SAFE_FUNCTIONS, то в переносимых приложениях с нитями нельзя вызывать tmpnam() с аргументом NULL.

ДЕФЕКТЫ

Никогда не используйте эти функции. Вместо них используйте mkstemp(3) или tmpfile(3).

СМОТРИТЕ ТАКЖЕ

⇧ Top