stdin   Début   Suivant   Sommaire   Préc.page.lue   Accueil
Section: Manuel du programmeur Linux (3)
Updated: 28 décembre 2007
Sommaire  



NOM   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
stdin, stdout, stderr - Flux d'entrées-sorties standards  



SYNOPSIS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
#include <stdio.h>

extern FILE *stdin;
extern FILE *stdout;
extern FILE *stderr;
 



DESCRIPTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Normalement, tout programme Unix démarre avec 3 flux déjà ouverts, l'un pour l'entrée des données, un autre pour la sortie des données, et un troisième pour l'affichage des messages de diagnostique ou d'erreur. Ces trois flux sont typiquement attachés au terminal de l'utilisateur (voir tty(4)), mais peuvent également être redirigés vers des fichiers ou vers d'autres périphériques suivant les choix du processus parent. (Voir le paragraphe « Redirection » dans sh(1)).

Le flux d'entrée est appelé « entrée standard » (standard input), le flux de sortie, « sortie standard » (standard output), et le flux d'erreur est souvent appelé « erreur standard » (standard error). Ces noms sont abrégés dans les dénominations symboliques de ces fichiers : stdin, stdout et stderr.

Chacun de ces symboles est une macro de stdio(3) de type pointeur sur un FILE, et peut être utilisé dans des fonctions comme fprintf(3) ou fread(3).

Comme les FILEs sont simplement des coquilles entourant les descripteurs de fichiers en ajoutant une mémoire tampon, il est également possible d'accéder aux fichiers Unix « bruts », avec des fonctions comme read(2) ou lseek(2). Au démarrage du programme, les descripteurs des fichiers associés aux flux stdin, stdout et stderr sont respectivement 0, 1, et 2. Les constantes symboliques STDIN_FILENO, STDOUT_FILENO et STDERR_FILENO sont définies avec ces valeurs dans <unistd.h>. (Appliquer freopen(3) sur l'un de ces flux peut modifier le numéro de descripteur de fichier associé au flux.)

Notez que l'utilisation conjointe des FILEs et des descripteurs bruts risque de produire des résultats inattendus, et doit être généralement évitée. Pour les plus masochistes d'entre-vous, POSIX.1 décrit en détail, dans son paragraphe 8.2.3, comment ces interactions sont censées fonctionner.

Une règle générale est que les descripteurs de fichiers sont manipulés par le noyau, alors que stdio est simplement une bibliothèque. Ceci signifie par exemple qu'après un exec(), le processus fils hérite de tous les descripteurs de fichiers ouverts, mais que les flux deviennent inaccessibles.

Comme les symboles stdin, stdout et stderr sont définis comme des macros, il est interdit de leur assigner une valeur. On peut utiliser la fonction de bibliothèque freopen(3) pour réassigner les flux standards de manière portable.

Les flux standards sont fermés lors d'un appel à exit(3), ou lors d'une fin normale de programme.  




CONFORMITÉ   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Les macros stdin, stdout et stderr sont conformes au standard ANSI C, et celui-ci stipule également que ces trois flux doivent être ouverts au démarrage du programme.  



NOTES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Le flux stderr n'a pas de tampon. Le flux stdout a un tampon de ligne lorsqu'il est dirigé vers un terminal. Les lignes partielles n'apparaîtront pas avant que fflush(3) ou exit(3) ne soient invoquées, ou qu'un retour-chariot soit écrit.

Ceci a parfois des effets inattendus, principalement lors du débogage des programmes. La gestion des tampons des flux standards (et des autres flux également) peut être modifiée en utilisant setbuf(3) ou setvbuf (3).

Remarquez que dans le cas où stdin est associée à un terminal, il peut également y avoir un tampon d'entrée dans le pilote de terminal, sans aucune relation avec le tampon de stdio. En fait, normalement, la saisie depuis un terminal est gérée avec un tampon de ligne dans le noyau. Cette gestion par le noyau peut être configurée en utilisant des appels système comme tcsetattr(3). Voir également stty(1) ou termios(3).  




VOIR AUSSI   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
sh(1), csh(1), open(2), fopen(3), stdio(3)  



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 30 avril 1998 et révisée le 29 décembre 2007.

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 stdin ». 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
NOM
SYNOPSIS
DESCRIPTION
CONFORMITÉ
NOTES
VOIR AUSSI
TRADUCTION

Ce document a été créé par man2html suivi de man2html.pl, le 17/10/2008 17:53:19, en utilisant les pages de 'man'.
 

Valid HTML 4.01 Transitional