Scroll to navigation

MKTEMP(3) Руководство программиста Linux MKTEMP(3)

ИМЯ

mktemp - создание уникального имени для временного файла

ОБЗОР

#include <stdlib.h>

char *mktemp(char *template);


Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

mktemp():

Начиная с glibc 2.12:
_BSD_SOURCE || _SVID_SOURCE ||
(_XOPEN_SOURCE >= 500 ||
_XOPEN_SOURCE && _XOPEN_SOURCE_EXTENDED) &&
!(_POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600)
До glibc 2.12:
_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE >= 500 || _XOPEN_SOURCE && _XOPEN_SOURCE_EXTENDED

ОПИСАНИЕ

Функция mktemp() генерирует на основе шаблона template уникальное имя для временного файла. Последние шесть символов template должны быть равны XXXXXX, они будут заменены на строку, которая сделает имя файла уникальным. Так как template будет меняться, он должен быть объявлен не строковой константой, а массивом символов.

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

Функция mktemp() всегда возвращает template. При создании уникального имени последние шесть байтов template заменяются так, что имя становится уникальным (то есть, такого имени ещё нет). Если уникальное имя невозможно создать, template будет равно пустой строке.

ОШИБКИ

Последние шесть символов template не равны XXXXXX.

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

4.3BSD, POSIX.1-2001. В POSIX.1-2008 спецификация mktemp() удалена.

ЗАМЕЧАНИЯ

Прототип для libc4, libc5, glibc1 находится в <unistd.h>; в glibc2 придерживается Single UNIX Specification, поэтому прототип для неё находится в <stdlib.h>.

ДЕФЕКТЫ

Никогда не используйте mktemp(). Некоторые реализации следуют 4.3BSD и заменяют XXXXXX текущим ID процесса и одним символом, поэтому может быть возвращено только 26 уникальных имен. С одной стороны такие имена легко подобрать, а с другой есть вероятность возникновения состязательности при проверке существования имени и открытия файла, поэтому каждое использование mktemp() является угрозой безопасности. Состязательность не может возникнуть, если использовать функцию mkstemp(3).

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

mkstemp(3), tempnam(3), tmpfile(3), tmpnam(3)

2010-09-20 GNU