GetFileAttributesA, fonction (fileapi.h)

Récupère les attributs du système de fichiers pour un fichier ou un répertoire spécifié.

Pour obtenir plus d’informations sur les attributs, utilisez la fonction GetFileAttributesEx .

Pour effectuer cette opération en tant qu’opération transactionnelle, utilisez la fonction GetFileAttributesTransacted .

Syntaxe

DWORD GetFileAttributesA(
  [in] LPCSTR lpFileName
);

Paramètres

[in] lpFileName

Nom du fichier ou du répertoire.

Par défaut, le nom est limité à MAX_PATH caractères. Pour étendre cette limite à 32 767 caractères de large, ajoutez « \\?\ » au chemin d’accès. Pour plus d’informations, consultez Nommage de fichiers, de chemins et d’espaces de noms.

Conseil

À compter de Windows 10, version 1607, vous pouvez choisir de supprimer la limitation de MAX_PATH sans précédencer « \?\ ». Pour plus d’informations, consultez la section « Limitation de longueur maximale du chemin d’accès » dans Naming Files, Paths et Namespaces .

Valeur retournée

Si la fonction réussit, la valeur de retour contient les attributs du fichier ou du répertoire spécifié. Pour obtenir la liste des valeurs d’attribut et leurs descriptions, consultez Constantes d’attributs de fichier.

Si la fonction échoue, la valeur de retour est INVALID_FILE_ATTRIBUTES. Pour obtenir des informations détaillées sur l’erreur, appelez GetLastError.

Notes

Lorsque GetFileAttributes est appelé sur un répertoire qui est un dossier monté, il retourne les attributs de système de fichiers du répertoire, et non ceux du répertoire racine dans le volume que le dossier monté associe au répertoire. Pour obtenir les attributs de fichier du volume associé, appelez GetVolumeNameForVolumeMountPoint pour obtenir le nom du volume associé. Utilisez ensuite le nom obtenu dans un appel à GetFileAttributes. Les résultats sont les attributs du répertoire racine sur le volume associé.

Si vous appelez GetFileAttributes pour un partage réseau, la fonction échoue et GetLastError retourne ERROR_BAD_NETPATH. Vous devez spécifier un chemin d’accès à un sous-dossier sur ce partage.

Dans Windows 8 et Windows Server 2012, cette fonction est prise en charge par les technologies suivantes.

Technologie Prise en charge
Protocole SMB (Server Message Block) 3.0 Oui
Basculement transparent SMB 3.0 (TFO) Oui
SMB 3.0 avec partages de fichiers avec montée en puissance sortante (SO) Oui
Cluster Shared Volume File System (CsvFS) Oui
Système de fichiers résilient (ReFS) Oui
 

Comportement de lien symbolique : si le chemin pointe vers un lien symbolique, la fonction retourne des attributs pour le lien symbolique.

Opérations traitées

Si un fichier est ouvert pour modification dans une transaction, aucun autre thread ne peut ouvrir le fichier pour modification tant que la transaction n’est pas validée. Par conséquent, si un thread traité ouvre le fichier en premier, tous les threads suivants qui tentent de modifier le fichier avant la validation de la transaction reçoivent une violation de partage. Si un thread non traité modifie le fichier avant le thread traité et que le fichier est toujours ouvert lorsque la transaction tente de l’ouvrir, la transaction reçoit l’erreur ERROR_TRANSACTIONAL_CONFLICT.

Exemples

Pour obtenir un exemple, consultez Récupération et modification d’attributs de fichier.

Notes

L’en-tête fileapi.h définit GetFileAttributes en tant qu’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. La combinaison 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.

Configuration requise

   
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

Voir aussi

DeviceIoControl

Constantes d’attribut de fichier

Fonctions de gestion de fichiers

FindFirstFile

FindNextFile

GetFileAttributesEx

GetFileAttributesTransacted

SetFileAttributes

Liens symboliques