Provided by: manpages-fr-dev_4.21.0-2_all bug

NOM

       fread, fwrite - Entrées/sorties binaires sur un flux

BIBLIOTHÈQUE

       Bibliothèque C standard (libc, -lc)

SYNOPSIS

       #include <stdio.h>

       size_t fread(void ptr[restrict .taille * .nmemb],
                    size_t taille, size_t nmemb,
                    FILE *restrict flux);
       size_t fwrite(const void ptr[restrict .taille * .nmemb],
                    size_t taille, size_t nmemb,
                    FILE *restrict flux);

DESCRIPTION

       La  fonction  fread()  lit  nbelem  éléments de données de taille octets chacun depuis le flux pointé par
       flux, et les stocke à l'emplacement pointé par ptr.

       La fonction fwrite() écrit nbelem éléments de données de taille octets chacun dans  le  flux  pointé  par
       flux, après les avoir récupérés depuis l'emplacement pointé par ptr.

       Pour des versions de ces fonctions ignorant les verrouillages, voir unlocked_stdio(3).

VALEUR RENVOYÉE

       En  cas  de  réussite,  fread() et fwrite() renvoient le nombre d'éléments lus ou écrits. Ce nombre n'est
       égal au nombre d'octets transférés que si taille est égal à 1. Si une erreur se produit, ou si la fin  du
       fichier est atteinte en lecture, le nombre renvoyé est plus petit que nbelem et peut même être nul.

       L'indicateur de position du flux est incrémenté du nombre d'octets ayant été lus ou écrits avec succès.

       fread()  ne  fait  pas  la différence entre la fin de fichier et une erreur, et l'appelant devra utiliser
       feof(3) et ferror(3) pour le savoir.

ATTRIBUTS

       Pour une explication des termes utilisés dans cette section, consulter attributes(7).
       ┌──────────────────────────────────────────────────────────────────────┬──────────────────────┬─────────┐
       │ InterfaceAttributValeur  │
       ├──────────────────────────────────────────────────────────────────────┼──────────────────────┼─────────┤
       │ fread(), fwrite()                                                    │ Sécurité des threads │ MT-Safe │
       └──────────────────────────────────────────────────────────────────────┴──────────────────────┴─────────┘

STANDARDS

       POSIX.1-2001, POSIX.1-2008, C99.

EXEMPLES

       Le programme ci-dessous montre l'utilisation de fread() pour parcourir l'exécutable ELF /bin/sh  en  mode
       binaire et afficher son code magique et sa classe :

           $ ./a.out
           ELF magic: 0x7f454c46
           Class: 0x02

   Source du programme

       #include <stdio.h>
       #include <stdlib.h>

       #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))

       int
       main(void)
       {
           FILE           *fp;
           size_t         ret;
           unsigned char  buffer[4];

           fp = fopen("/bin/sh", "rb");
           if (!fp) {
               perror("fopen");
               return EXIT_FAILURE;
           }

           ret = fread(buffer, sizeof(*buffer), ARRAY_SIZE(buffer), fp);
           if (ret != ARRAY_SIZE(buffer)) {
               fprintf(stderr, "fread() failed: %zu\n", ret);
               exit(EXIT_FAILURE);
           }

           printf("ELF magic: %#04x%02x%02x%02x\n", buffer[0], buffer[1],
                  buffer[2], buffer[3]);

           ret = fread(buffer, 1, 1, fp);
           if (ret != 1) {
               fprintf(stderr, "fread() a échoué : %zu\n", ret);
               exit(EXIT_FAILURE);
           }

           printf("Class: %#04x\n", buffer[0]);

           fclose(fp);

           exit(EXIT_SUCCESS);
       }

VOIR AUSSI

       read(2), write(2), feof(3), ferror(3), unlocked_stdio(3)

TRADUCTION

       La   traduction   française   de   cette   page   de   manuel   a   été   créée   par  Christophe  Blaess
       <https://www.blaess.fr/christophe/>, Stéphan Rafin  <stephan.rafin@laposte.net>,  Thierry  Vignaud  <tvi‐
       gnaud@mandriva.com>,  François  Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fe‐
       vrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau  <jcristau@de‐
       bian.org>,   Thomas   Huriaux   <thomas.huriaux@gmail.com>,  Nicolas  François  <nicolas.francois@centra‐
       liens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>,
       Denis  Barbier  <barbier@debian.org>,  David  Prévot  <david@tilapin.org>,   Frédéric   Hantrais   <fhan‐
       trais@gmail.com> et Lucien Gentis <lucien.gentis@waika9.com>

       Cette  traduction  est  une  documentation libre ; veuillez vous reporter à la GNU General Public License
       version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

       Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à  de‐
       bian-l10n-french@lists.debian.org.

Pages du manuel de Linux 6.03                   29 décembre 2022                                        fread(3)