GetTempFileNameA, fonction (fileapi.h)
Crée un nom pour le fichier temporaire. Si un nom de fichier unique est généré, un fichier vide est créé et le gestionnaire de ce fichier est libéré ; dans le cas contraire, seul un nom de fichier est généré.
Syntaxe
UINT GetTempFileNameA(
[in] LPCSTR lpPathName,
[in] LPCSTR lpPrefixString,
[in] UINT uUnique,
[out] LPSTR lpTempFileName
);
Paramètres
[in] lpPathName
Chemin du répertoire pour le nom de fichier. Les applications spécifient généralement un point (.) pour le répertoire actif ou le résultat de la fonction GetTempPath . La chaîne ne peut pas dépasser MAX_PATH à 14 caractères ou GetTempFileName échoue. Si ce paramètre a la valeur NULL, la fonction échoue.
[in] lpPrefixString
Chaîne de préfixe terminée par null. La fonction utilise jusqu’aux trois premiers caractères de cette chaîne comme préfixe du nom de fichier. Cette chaîne doit se composer de caractères dans le jeu de caractères défini par OEM.
[in] uUnique
Entier non signé à utiliser pour créer le nom de fichier temporaire. Pour plus d'informations, consultez la section Notes.
Si uUnique est égal à zéro, la fonction tente de former un nom de fichier unique à l’aide de l’heure système actuelle. Si le fichier existe déjà, le nombre est augmenté d’un et les fonctions testent si ce fichier existe déjà. Cela se poursuit jusqu’à ce qu’un nom de fichier unique soit trouvé ; la fonction crée un fichier de ce nom et le ferme. Notez que la fonction ne tente pas de vérifier l’unicité du nom de fichier lorsque uUnique est différent de zéro.
[out] lpTempFileName
Pointeur vers la mémoire tampon qui reçoit le nom du fichier temporaire. Cette mémoire tampon doit être MAX_PATH caractères pour prendre en charge le chemin d’accès plus le caractère null de fin.
Valeur retournée
Si la fonction réussit, la valeur de retour spécifie la valeur numérique unique utilisée dans le nom de fichier temporaire. Si le paramètre uUnique est différent de zéro, la valeur de retour spécifie ce même nombre.
Si la fonction échoue, la valeur de retour est égale à zéro. Pour obtenir des informations détaillées sur l’erreur, appelez GetLastError.
Voici une valeur de retour possible.
Valeur retournée | Description |
---|---|
|
La longueur de la chaîne pointée vers le paramètre lpPathName est supérieure à MAX_PATH à 14 caractères. |
Notes
La fonction GetTempFileName crée un nom de fichier temporaire au format suivant :
<path>\<pre><uuuuuu>. TMP
Le tableau suivant décrit la syntaxe du nom de fichier.
Composant | Signification |
---|---|
<path> | Chemin d’accès spécifié par le paramètre lpPathName |
<pre> | Trois premières lettres de la chaîne lpPrefixString |
<Uuuu> | Valeur hexadécimale de uUnique |
Si uUnique est égal à zéro, GetTempFileName crée un fichier vide et le ferme. Si uUnique n’est pas zéro, vous devez créer le fichier vous-même. Seul un nom de fichier est créé, car GetTempFileName n’est pas en mesure de garantir que le nom de fichier est unique.
Seuls les 16 bits inférieurs du paramètre uUnique sont utilisés. Cela limite GetTempFileName à un maximum de 65 535 noms de fichiers uniques si les paramètres lpPathName et lpPrefixString restent identiques.
En raison de l’algorithme utilisé pour générer des noms de fichiers, GetTempFileName peut mal fonctionner lors de la création d’un grand nombre de fichiers avec le même préfixe. Dans ce cas, il est recommandé de construire des noms de fichiers uniques basés sur des GUID.
Les fichiers temporaires dont les noms ont été créés par cette fonction ne sont pas automatiquement supprimés. Pour supprimer ces fichiers, appelez DeleteFile.
Pour éviter les problèmes résultant de la conversion d’une chaîne ANSI, une application doit appeler la fonction CreateFile pour créer un fichier temporaire.
Dans Windows 8 et Windows Server 2012, cette fonction est prise en charge par les technologies suivantes.
Technologie | Prise en charge |
---|---|
Protocole Server Message Block (SMB) 3.0 | Oui |
Basculement transparent SMB 3.0 (TFO) | Oui |
SMB 3.0 avec partages de fichiers avec montée en puissance parallèle (SO) | Oui |
Système de fichiers du volume partagé de cluster (CsvFS) | Oui |
Système de fichiers résilient (ReFS) | Oui |
Exemples
Pour obtenir un exemple, consultez Création et utilisation d’un fichier temporaire.
Notes
L’en-tête fileapi.h définit GetTempFileName comme un alias qui sélectionne automatiquement la version ANSI ou Unicode de cette fonction en fonction de la définition de la constante de préprocesseur UNICODE. Le mélange de l’utilisation de l’alias neutre en encodage avec du code qui n’est pas neutre en encodage peut entraîner des incompatibilités qui entraînent des erreurs de compilation ou d’exécution. Pour plus d’informations, consultez Conventions pour les prototypes de fonction.
Spécifications
Client minimal pris en charge | Windows XP [applications de bureau | applications UWP] |
Serveur minimal pris en charge | Windows Server 2003 [applications de bureau | applications UWP] |
Plateforme cible | Windows |
En-tête | fileapi.h (inclure Windows.h) |
Bibliothèque | Kernel32.lib |
DLL | Kernel32.dll |