fgets
|
Défini dans l'en-tête
<stdio.h>
|
||
|
char
*
fgets
(
char
*
str,
int
count,
FILE
*
stream
)
;
|
(jusqu'à C99) | |
|
char
*
fgets
(
char
*
restrict
str,
int
count,
FILE
*
restrict
stream
)
;
|
(depuis C99) | |
Lit au plus count - 1 caractères depuis le flux de fichier donné et les stocke dans le tableau de caractères pointé par str . L'analyse s'arrête si un caractère de nouvelle ligne est trouvé (auquel cas str contiendra ce caractère de nouvelle ligne) ou si la fin de fichier est atteinte. Si des octets sont lus et qu'aucune erreur ne survient, écrit un caractère nul à la position immédiatement après le dernier caractère écrit dans str .
Table des matières |
Paramètres
| str | - | pointeur vers un élément d'un tableau de caractères |
| count | - | nombre maximum de caractères à écrire (généralement la longueur de str ) |
| stream | - | flux de fichier depuis lequel lire les données |
Valeur de retour
str en cas de succès, pointeur nul en cas d'échec.
Si la condition de fin de fichier est rencontrée, positionne l'indicateur eof sur stream (voir feof() ). Ceci n'est considéré comme un échec que si aucun octet n'a été lu, auquel cas un pointeur nul est retourné et le contenu du tableau pointé par str n'est pas modifié (c'est-à-dire que le premier octet n'est pas écrasé par un caractère nul).
Si l'échec a été causé par une autre erreur, positionne l'indicateur d'erreur (voir ferror() ) sur stream . Le contenu du tableau pointé par str est indéterminé (il pourrait même ne pas être terminé par un caractère nul).
Notes
POSIX exige en outre que fgets définisse errno si une erreur de lecture se produit.
Bien que la spécification standard soit peu claire dans les cas où count <= 1 , les implémentations courantes le font
- si count < 1 , ne rien faire, signaler une erreur,
- si count == 1 ,
-
- certaines implémentations ne font rien, signalent une erreur,
- d'autres ne lisent rien, stockent zéro dans str [ 0 ] , signalent un succès.
Exemple
#include <stdio.h> #include <stdlib.h> int main(void) { FILE* tmpf = tmpfile(); fputs("Alan Turing\n", tmpf); fputs("John von Neumann\n", tmpf); fputs("Alonzo Church\n", tmpf); rewind(tmpf); char buf[8]; while (fgets(buf, sizeof buf, tmpf) != NULL) printf("\"%s\"\n", buf); if (feof(tmpf)) puts("End of file reached"); }
Sortie :
"Alan Tu" "ring " "John vo" "n Neuma" "nn " "Alonzo " "Church " End of file reached
Références
- Norme C23 (ISO/CEI 9899:2024) :
-
- 7.21.7.2 La fonction fgets (p: TBD)
- Norme C17 (ISO/CEI 9899:2018) :
-
- 7.21.7.2 La fonction fgets (p: 241)
- Norme C11 (ISO/CEI 9899:2011) :
-
- 7.21.7.2 La fonction fgets (p: 331)
- Norme C99 (ISO/CEI 9899:1999) :
-
- 7.19.7.2 La fonction fgets (p: 296)
- Norme C89/C90 (ISO/IEC 9899:1990) :
-
- 4.9.7.2 La fonction fgets
Voir aussi
|
(C11)
(C11)
(C11)
|
lit une entrée formatée depuis
stdin
, un flux de fichier ou un tampon
(fonction) |
|
(supprimé en C11)
(C11)
|
lit une chaîne de caractères depuis
stdin
(fonction) |
|
écrit une chaîne de caractères vers un flux de fichier
(fonction) |
|
|
(dynamic memory TR)
|
lit depuis un flux dans un tampon automatiquement redimensionné jusqu'au délimiteur/fin de ligne
(fonction) |
|
Documentation C++
pour
fgets
|
|