fopen | Début | Suivant | Sommaire | Préc.page.lue | Accueil |
NOM | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
SYNOPSIS | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
#include <stdio.h> FILE *fopen (const char *path, const char *mode);
FILE *fdopen (int fd, const char *mode);
FILE *freopen (const char *path, const char *mode, FILE *stream);
Exigences de macros de test de fonctionalités pour la glibc (voir feature_test_macros(7)) :
DESCRIPTION | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
L'argument mode pointe vers une chaîne commençant par l'une des séquences suivantes (d'autres caractères peuvent suivre la séquence) :
La chaîne mode peut également inclure la lettre « b » comme 3ème caractère, ou même entre les deux caractères d'une des séquences à 2 lettres vues ci-dessus. Ce mode sert uniquement à assurer la compatibilité avec C89 et n'a aucun effet. Le « b » est ignoré sur tous les systèmes compatibles POSIX, y compris Linux. (D'autres systèmes peuvent traiter les fichiers de texte et les fichiers binaires différement, et l'ajout du « b » peut être une bonne idée si vous faites des entrées-sorties binaires et que votre programme risque d'être porté sur un environnement non Unix).
Tout fichier créé aura le mode S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH (0666), qui sera ensuite modifié par la valeur d'umask du processus. Voir umask(2).
Les lectures et les écritures peuvent être mélangées sur les flux en lecture et écriture, dans un ordre quelconque, et sans besoin de positionnement entre les entrées et les sorties, à moins qu'une lecture atteigne la fin du fichier. (Sinon sur certains systèmes la lecture peut renvoyer les données provenant d'une écriture autre que la dernière). Une bonne habitude consiste donc à intercaler un fseek(3) ou fgetpos(3) entre les lectures et les écritures sur le même flux. Ces opérations peuvent être visiblement sans effet comme fseek(..., 0L, SEEK_CUR) et ne servant que pour l'effet de bord de synchronisation.
Ouvrir un fichier en mode ajout (a en premier caractère dans le mode) feront agir toutes les opérations d'écriture à la fin du flux, comme si elles étaient précédées par un appel
fseek(stream,0,SEEK_END);
systèmatique.
La fonction fdopen() associe un flux avec un descripteur de fichier fd existant. Le mode du flux (« r », « "r+ », « w », « w+ », « a », ou « a+ ») doit être compatible avec celui du descripteur de fichier. L'indicateur de position du nouveau flux prend la même valeur que celui de fd, et les indicateurs d'erreur et de fin-de-fichier sont effacés. Les modes « w » et « w+ » ne tronquent pas le fichier. Le descripteur n'est pas dupliqué par dup(2), et sera refermé lorsque le flux créé par fdopen() sera refermé. L'appel de fdopen() sur un objet en mémoire partagée est indéfini.
La fonction freopen() ouvre le fichier dont le nom se trouve dans la chaîne de caractères pointée par path et lui associe le flux pointé par stream. Le flux original, s'il existe, est fermé. L'argument mode est utilisé exactement comme avec fopen(). La principale utilisation de freopen() est de modifier le fichier associé aux flux standards de texte (stderr, stdin, ou stdout).
VALEUR RENVOYÉE | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
ERREURS | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
Les fonctions fopen(), fdopen() et freopen() peuvent également échouer et positionner dans errno une des erreurs susceptibles de se produire avec malloc(3).
La fonction fopen() peut aussi échouer et positionner dans errno une des erreurs susceptibles de se produire avec open(2).
La fonction fdopen() peut aussi échouer et positionner dans errno une des erreurs susceptibles de se produire avec fcntl(2).
La fonction freopen() peut aussi échouer et positionner dans errno une des erreurs susceptibles de se produire avec open(2), fclose(3) et fflush(3).
CONFORMITÉ | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
NOTES | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
Notes glibc | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
VOIR AUSSI | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
TRADUCTION | Début | Précédent | Suivant | Sommaire | Préc.page.lue | Accueil |
Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 23 octobre 1996 et révisée le 8 janvier 2008.
L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 3 fopen ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
Sommaire | Début | Suivant | Sommaire | Préc.page.lue | Accueil |
Table des mots clés | Début | Suivant | Sommaire | Préc.page.lue | Accueil |
a | DESCRIPTION |
a+ | DESCRIPTION |
c (depuis glibc 2.3.3) | Notes glibc |
e (depuis glibc 2.7) | Notes glibc |
EINVAL | ERREURS |
m (depuis glibc 2.3) | Notes glibc |
r | DESCRIPTION |
r+ | DESCRIPTION |
w | DESCRIPTION |
w+ | DESCRIPTION |
x | Notes glibc |