Namespaces
Variants

printf, fprintf, sprintf, snprintf, printf_s, fprintf_s, sprintf_s, snprintf_s

From cppreference.net
< c ‎ | io
Défini dans l'en-tête <stdio.h>
(1)
int printf ( const char * format, ... ) ;
(jusqu'à C99)
int printf ( const char * restrict format, ... ) ;
(depuis C99)
(2)
int fprintf ( FILE * stream, const char * format, ... ) ;
(jusqu'à C99)
int fprintf ( FILE * restrict stream, const char * restrict format, ... ) ;
(depuis C99)
(3)
int sprintf ( char * buffer, const char * format, ... ) ;
(jusqu'à C99)
int sprintf ( char * restrict buffer, const char * restrict format, ... ) ;
(depuis C99)
int snprintf ( char * restrict buffer, size_t bufsz,
const char * restrict format, ... ) ;
(4) (depuis C99)
int printf_s ( const char * restrict format, ... ) ;
(5) (depuis C11)
int fprintf_s ( FILE * restrict stream, const char * restrict format, ... ) ;
(6) (depuis C11)
int sprintf_s ( char * restrict buffer, rsize_t bufsz,
const char * restrict format, ... ) ;
(7) (depuis C11)
int snprintf_s ( char * restrict buffer, rsize_t bufsz,
const char * restrict format, ... ) ;
(8) (depuis C11)

Charge les données depuis les emplacements donnés, les convertit en équivalents de chaînes de caractères et écrit les résultats vers divers récepteurs/flux :

1) Écrit les résultats dans le flux de sortie stdout .
2) Écrit les résultats dans le flux de sortie stream .
3) Écrit les résultats dans une chaîne de caractères buffer . Le comportement est indéfini si la chaîne à écrire (plus le caractère nul de fin) dépasse la taille du tableau pointé par buffer .
4) Écrit les résultats dans une chaîne de caractères buffer . Au maximum bufsz - 1 caractères sont écrits. La chaîne de caractères résultante sera terminée par un caractère nul, sauf si bufsz est zéro. Si bufsz est zéro, rien n'est écrit et buffer peut être un pointeur nul, cependant la valeur de retour (nombre d'octets qui seraient écrits sans inclure le terminateur nul) est toujours calculée et renvoyée.
5-8) Identique à (1-4) , sauf que les erreurs suivantes sont détectées à l'exécution et appellent la fonction constraint handler actuellement installée :
  • le spécificateur de conversion %n est présent dans format
  • un des arguments correspondant à %s est un pointeur nul
  • stream ou format ou buffer est un pointeur nul
  • bufsz est zéro ou supérieur à RSIZE_MAX
  • des erreurs d'encodage surviennent dans l'un des spécificateurs de conversion de chaîne et de caractère
  • (pour sprintf_s uniquement), la chaîne à stocker dans buffer (y compris le caractère nul final) dépasserait bufsz .
Comme pour toutes les fonctions à vérification de limites, printf_s , fprintf_s , sprintf_s , et snprintf_s ne sont garanties d'être disponibles que si __STDC_LIB_EXT1__ est défini par l'implémentation et si l'utilisateur définit __STDC_WANT_LIB_EXT1__ à la constante entière 1 avant d'inclure <stdio.h> .

Table des matières

Paramètres

stream - flux de fichier de sortie vers lequel écrire
buffer - pointeur vers une chaîne de caractères à écrire
bufsz - jusqu'à bufsz - 1 caractères peuvent être écrits, plus le terminateur nul
format - pointeur vers une chaîne d'octets terminée par un nul spécifiant comment interpréter les données
... - arguments spécifiant les données à imprimer. Si un argument après promotions d'arguments par défaut n'est pas du type attendu par la spécification de conversion correspondante (le type attendu est le type promu ou un type compatible du type promu), ou s'il y a moins d'arguments que requis par format , le comportement est indéfini. S'il y a plus d'arguments que requis par format , les arguments superflus sont évalués et ignorés.

La chaîne de format est composée de caractères octets ordinaires (sauf % ), qui sont copiés inchangés dans le flux de sortie, et de spécifications de conversion. Chaque spécification de conversion a le format suivant :

  • introductoire % caractère.
  • (optionnel) un ou plusieurs drapeaux qui modifient le comportement de la conversion :
  • - : le résultat de la conversion est justifié à gauche dans le champ (par défaut il est justifié à droite).
  • + : le signe des conversions signées est toujours ajouté au début du résultat de la conversion (par défaut le résultat est précédé d'un moins uniquement lorsqu'il est négatif).
  • espace : si le résultat d'une conversion signée ne commence pas par un caractère de signe, ou est vide, un espace est ajouté au début du résultat. Il est ignoré si le drapeau + est présent.
  • # : la forme alternative de la conversion est effectuée. Voir le tableau ci-dessous pour les effets exacts, sinon le comportement est indéfini.
  • 0 : pour les conversions de nombres entiers et à virgule flottante, des zéros non significatifs sont utilisés pour remplir le champ au lieu des caractères espace . Pour les nombres entiers, il est ignoré si la précision est explicitement spécifiée. Pour d'autres conversions, l'utilisation de ce drapeau entraîne un comportement indéfini. Il est ignoré si le drapeau - est présent.
  • (optionnel) valeur entière ou * qui spécifie la largeur minimale du champ. Le résultat est complété avec des caractères espace (par défaut), si nécessaire, à gauche lors de l'alignement à droite, ou à droite lors de l'alignement à gauche. Dans le cas où * est utilisé, la largeur est spécifiée par un argument supplémentaire de type int , qui apparaît avant l'argument à convertir et l'argument fournissant la précision si celle-ci est fournie. Si la valeur de l'argument est négative, cela entraîne l'activation du drapeau - et une largeur de champ positive (Note : Ceci est la largeur minimale : La valeur n'est jamais tronquée.).
  • (optionnel) . suivi d'un nombre entier ou * , ou ni l'un ni l'autre, qui spécifie la précision de la conversion. Dans le cas où * est utilisé, la précision est spécifiée par un argument supplémentaire de type int , qui apparaît avant l'argument à convertir, mais après l'argument fournissant la largeur minimale du champ si celui-ci est fourni. Si la valeur de cet argument est négative, elle est ignorée. Si ni un nombre ni * n'est utilisé, la précision est prise comme zéro. Voir le tableau ci-dessous pour les effets exacts de la précision .
  • (optionnel) modificateur de longueur qui spécifie la taille de l'argument (en combinaison avec le spécificateur de format de conversion, il spécifie le type de l'argument correspondant).
  • spécificateur de format de conversion.

Les spécificateurs de format suivants sont disponibles :

Spécificateur
de Conversion
Explication Type d'Argument
Attendu
Modificateur de longueur→ hh h aucun l ll j z t L
Uniquement disponible depuis C99→ Oui Oui Oui Oui Oui
% Écrit le caractère littéral % . La spécification de conversion complète doit être %% . N/A N/A N/A N/A N/A N/A N/A N/A N/A
c

Écrit un caractère unique .

  • L'argument est d'abord converti en unsigned char .
  • Si le modificateur l est utilisé, l'argument est d'abord converti en chaîne de caractères comme avec %ls avec un argument wchar_t [ 2 ] .
N/A N/A
int
wint_t
N/A N/A N/A N/A N/A
s

Écrit une chaîne de caractères .

  • L'argument doit être un pointeur vers l'élément initial d'un tableau de caractères.
  • Précision spécifie le nombre maximum d'octets à écrire. Si Précision n'est pas spécifiée, écrit chaque octet jusqu'au premier terminateur nul (non inclus).
  • Si le spécificateur l est utilisé, l'argument doit être un pointeur vers l'élément initial d'un tableau de wchar_t , qui est converti en tableau de caractères comme par un appel à wcrtomb avec un état de conversion initialisé à zéro.
N/A N/A
char *
wchar_t *
N/A N/A N/A N/A N/A
d
i

Convertit un entier signé en représentation décimale [-]dddd .

  • Précision spécifie le nombre minimum de chiffres à afficher. La précision par défaut est 1 .
  • Si la valeur convertie et la précision sont toutes deux 0 , la conversion ne produit aucun caractère.
  • Pour le modificateur z , le type d'argument attendu est la version signée de size_t .
signed char
short
int
long
long long
N/A
o

Convertit un entier non signé en représentation octale oooo .

  • Précision spécifie le nombre minimum de chiffres à afficher. La précision par défaut est 1 .
  • Si la valeur convertie et la précision sont toutes deux 0 , la conversion ne produit aucun caractère.
  • Dans l' implémentation alternative , la précision est augmentée si nécessaire pour écrire un zéro initial. Dans ce cas, si la valeur convertie et la précision sont toutes deux 0 , un seul 0 est écrit.
unsigned char
unsigned short
unsigned int
unsigned long
unsigned long long
version non signée de ptrdiff_t
N/A
x
X

Convertit un entier non signé en représentation hexadécimale hhhh .

  • Pour la conversion x les lettres abcdef sont utilisées.
  • Pour la conversion X les lettres ABCDEF sont utilisées.
  • Précision spécifie le nombre minimum de chiffres à afficher. La précision par défaut est 1 .
  • Si la valeur convertie et la précision sont toutes deux 0 la conversion ne produit aucun caractère.
  • Dans l' implémentation alternative 0x ou 0X est préfixé aux résultats si la valeur convertie est non nulle.
N/A
u

Convertit un entier non signé en représentation décimale dddd .

  • Précision spécifie le nombre minimum de chiffres à afficher.
  • La précision par défaut est 1 .
  • Si la valeur convertie et la précision sont toutes deux 0 , la conversion ne produit aucun caractère.
N/A
f
F (C99)

Convertit un nombre à virgule flottante en notation décimale selon le format [-]ddd.ddd .

  • Précision spécifie le nombre exact de chiffres à afficher après le séparateur décimal.
  • La précision par défaut est 6 .
  • Dans l' implémentation alternative , le séparateur décimal est écrit même si aucun chiffre ne le suit.
  • Pour le style de conversion des infinis et des NaN, voir les notes .
N/A N/A
double
double (C99)
N/A N/A N/A N/A
long double
e
E

Convertit un nombre à virgule flottante en notation exponentielle décimale.

  • Pour le style de conversion e , la notation [-]d.ddd  e ±dd est utilisée.
  • Pour le style de conversion E , la notation [-]d.ddd  E ±dd est utilisée.
  • L'exposant contient au moins deux chiffres, plus de chiffres ne sont utilisés que si nécessaire.
  • Si la valeur est 0 , l'exposant est également 0 .
  • Précision spécifie le nombre exact de chiffres à afficher après le caractère de point décimal.
  • La précision par défaut est 6 .
  • Dans l' implémentation alternative , le caractère de point décimal est écrit même si aucun chiffre ne le suit.
  • Pour la conversion de l'infini et de la valeur non numérique, voir les notes .
N/A N/A N/A N/A N/A N/A
a
A

(C99)

Convertit un nombre à virgule flottante en notation exponentielle hexadécimale.

  • Pour le style de conversion a , la notation [-]  0x h.hhh  p ±d est utilisée.
  • Pour le style de conversion A , la notation [-]  0X h.hhh  P ±d est utilisée.
  • Le premier chiffre hexadécimal n'est pas 0 si l'argument est une valeur à virgule flottante normalisée.
  • Si la valeur est 0 , l'exposant est également 0 .
  • Précision spécifie le nombre exact de chiffres à afficher après le caractère de point hexadécimal.
  • La précision par défaut est suffisante pour la représentation exacte de la valeur.
  • Dans l' implémentation alternative , le caractère de point décimal est écrit même si aucun chiffre ne le suit.
  • Pour la conversion des infinis et des NaN, voir les notes .
N/A N/A N/A N/A N/A N/A
g
G

Convertit un nombre à virgule flottante en notation décimale ou en notation exponentielle décimale selon la valeur et la précision .

  • Pour le style de conversion g , la conversion sera effectuée avec le style e ou f .
  • Pour le style de conversion G , la conversion sera effectuée avec le style E ou f (jusqu'en C99) F (depuis C99) .
  • Soit P égal à la précision si elle est non nulle, 6 si la précision n'est pas spécifiée, ou 1 si la précision est 0 . Alors, si une conversion avec le style E aurait un exposant X :
    • Si P > X ≥ −4 , la conversion est effectuée avec le style f ou F (depuis C99) et la précision P − 1 − X .
    • Sinon, la conversion est effectuée avec le style e ou E et la précision P − 1 .
  • Sauf si la représentation alternative est demandée, les zéros de fin sont supprimés, et le caractère de point décimal est également supprimé s'il ne reste aucune partie fractionnaire.
  • Pour la conversion des infinis et des NaN, voir les notes .
N/A N/A N/A N/A N/A N/A
n

Retourne le nombre de caractères écrits jusqu'à présent par cet appel de la fonction.

  • Le résultat est écrit dans la valeur pointée par l'argument.
  • La spécification ne doit contenir aucun indicateur , largeur de champ , ou précision .
  • Pour le modificateur z , le type d'argument attendu est S * , où S est la version signée de size_t .
signed char *
short *
int *
long *
long long *
N/A
p

Écrit une séquence de caractères définie par l'implémentation représentant un pointeur .

N/A N/A
void *
N/A N/A N/A N/A N/A N/A
Notes

Les fonctions de conversion en virgule flottante convertissent l'infini en inf ou infinity . Le choix est défini par l'implémentation.

La valeur non numérique est convertie en nan ou nan( char_sequence ) . Le choix est défini par l'implémentation.

Les conversions F , E , G , A produisent INF , INFINITY , NAN à la place.

Le spécificateur de conversion utilisé pour afficher char , unsigned char , signed char , short , et unsigned short attend des types promus des promotions d'arguments par défaut , mais avant l'affichage, sa valeur sera convertie en char , unsigned char , signed char , short , et unsigned short . Il est sûr de passer des valeurs de ces types en raison de la promotion qui a lieu lors de l'appel d'une fonction variadique.

Les spécifications de conversion correctes pour les types de caractères de largeur fixe ( int8_t , etc.) sont définies dans l'en-tête <inttypes.h> (bien que PRIdMAX , PRIuMAX , etc. soient synonymes de %jd , %ju , etc.).

Le spécificateur de conversion d'écriture en mémoire %n est une cible courante d'exploitations de sécurité lorsque les chaînes de format dépendent d'une entrée utilisateur et n'est pas pris en charge par la famille de fonctions printf_s à vérification de limites (depuis C11) .

Il y a un point de séquence après l'action de chaque spécificateur de conversion ; cela permet de stocker plusieurs résultats %n dans la même variable ou, comme cas particulier, d'afficher une chaîne modifiée par un précédent %n dans le même appel.

Si une spécification de conversion est invalide, le comportement est indéfini.

Valeur de retour

1,2) nombre de caractères transmis au flux de sortie ou valeur négative si une erreur de sortie ou une erreur d'encodage (pour les spécificateurs de conversion de chaîne et de caractère) s'est produite.
3) nombre de caractères écrits dans le buffer (sans compter le caractère nul de fin), ou une valeur négative si une erreur d'encodage (pour les spécificateurs de conversion de chaîne et de caractère) s'est produite.
4) nombre de caractères (sans inclure le caractère nul de terminaison) qui auraient été écrits dans le buffer si bufsz était ignoré, ou une valeur négative si une erreur d'encodage (pour les spécificateurs de conversion de chaîne et de caractère) s'est produite.
5,6) nombre de caractères transmis au flux de sortie ou valeur négative si une erreur de sortie, une violation des contraintes d'exécution ou une erreur d'encodage s'est produite.
7) nombre de caractères écrits dans le buffer , sans compter le caractère nul (qui est toujours écrit tant que buffer n'est pas un pointeur nul et bufsz n'est pas zéro et pas supérieur à RSIZE_MAX ), ou zéro en cas de violation des contraintes d'exécution, et valeur négative en cas d'erreurs d'encodage.
8) nombre de caractères non compris le caractère nul de fin (qui est toujours écrit tant que buffer n'est pas un pointeur nul et bufsz n'est pas zéro et pas supérieur à RSIZE_MAX ), qui aurait été écrit dans buffer si bufsz était ignoré, ou une valeur négative si une violation des contraintes d'exécution ou une erreur d'encodage s'est produite.

Notes

La norme C et POSIX spécifient que le comportement de sprintf et de ses variantes est indéfini lorsqu'un argument chevauche le tampon de destination. Exemple :

sprintf(dst, "%s and %s", dst, t); // <- cassé : comportement indéfini

POSIX spécifie que errno est défini en cas d'erreur. Il spécifie également des spécifications de conversion supplémentaires, notamment la prise en charge du réordonnancement des arguments ( n$ immédiatement après % indique le n ième argument).

Appeler snprintf avec une bufsz nulle et un pointeur nul pour buffer est utile pour déterminer la taille de tampon nécessaire pour contenir la sortie :

const char fmt[] = "sqrt(2) = %f";
int sz = snprintf(NULL, 0, fmt, sqrt(2));
char buf[sz + 1]; // note +1 pour l'octet nul de terminaison
snprintf(buf, sizeof buf, fmt, sqrt(2));
Seul le commentaire a été traduit en français : "note +1 pour l'octet nul de terminaison". Tous les autres éléments (balises HTML, code C++, termes techniques) ont été conservés dans leur forme originale.

snprintf_s , tout comme snprintf , mais contrairement à sprintf_s , tronquera la sortie pour tenir dans bufsz - 1 .

Exemple

#include <inttypes.h>
#include <stdint.h>
#include <stdio.h>
int main(void)
{
    const char* s = "Hello";
    printf("Strings:\n"); // same as puts("Strings");
    printf(" padding:\n");
    printf("\t[%10s]\n", s);
    printf("\t[%-10s]\n", s);
    printf("\t[%*s]\n", 10, s);
    printf(" truncating:\n");
    printf("\t%.4s\n", s);
    printf("\t%.*s\n", 3, s);
    printf("Characters:\t%c %%\n", 'A');
    printf("Integers:\n");
    printf("\tDecimal:\t%i %d %.6i %i %.0i %+i %i\n",
                         1, 2,   3, 0,   0,  4,-4);
    printf("\tHexadecimal:\t%x %x %X %#x\n", 5, 10, 10, 6);
    printf("\tOctal:\t\t%o %#o %#o\n", 10, 10, 4);
    printf("Floating-point:\n");
    printf("\tRounding:\t%f %.0f %.32f\n", 1.5, 1.5, 1.3);
    printf("\tPadding:\t%05.2f %.2f %5.2f\n", 1.5, 1.5, 1.5);
    printf("\tScientific:\t%E %e\n", 1.5, 1.5);
    printf("\tHexadecimal:\t%a %A\n", 1.5, 1.5);
    printf("\tSpecial values:\t0/0=%g 1/0=%g\n", 0.0 / 0.0, 1.0 / 0.0);
    printf("Fixed-width types:\n");
    printf("\tLargest 32-bit value is %" PRIu32 " or %#" PRIx32 "\n",
                                     UINT32_MAX,     UINT32_MAX );
}

Sortie possible :

Strings:
 padding:
        [     Hello]
        [Hello     ]
        [     Hello]
 truncating:
        Hell
        Hel
Characters:     A %
Integers:
        Decimal:        1 2 000003 0  +4 -4
        Hexadecimal:    5 a A 0x6
        Octal:          12 012 04
Floating-point:
        Rounding:       1.500000 2 1.30000000000000004440892098500626
        Padding:        01.50 1.50  1.50
        Scientific:     1.500000E+00 1.500000e+00
        Hexadecimal:    0x1.8p+0 0X1.8P+0
        Special values: 0/0=-nan 1/0=inf
Fixed-width types:
        Largest 32-bit value is 4294967295 or 0xffffffff

Références

  • Norme C23 (ISO/CEI 9899:2024) :
  • 7.21.6.1 La fonction fprintf (p: TBD)
  • 7.21.6.3 La fonction printf (p: TBD)
  • 7.21.6.5 La fonction snprintf (p: TBD)
  • 7.21.6.6 La fonction sprintf (p: TBD)
  • K.3.5.3.1 La fonction fprintf_s (p: TBD)
  • K.3.5.3.3 La fonction printf_s (p: TBD)
  • K.3.5.3.5 La fonction snprintf_s (p: TBD)
  • K.3.5.3.6 La fonction sprintf_s (p: TBD)
  • Norme C17 (ISO/CEI 9899:2018) :
  • 7.21.6.1 La fonction fprintf (p: 225-230)
  • 7.21.6.3 La fonction printf (p: 236)
  • 7.21.6.5 La fonction snprintf (p: 237)
  • 7.21.6.6 La fonction sprintf (p: 237)
  • K.3.5.3.1 La fonction fprintf_s (p: 430)
  • K.3.5.3.3 La fonction printf_s (p: 432)
  • K.3.5.3.5 La fonction snprintf_s (p: 432-433)
  • K.3.5.3.6 La fonction sprintf_s (p: 433)
  • Norme C11 (ISO/CEI 9899:2011) :
  • 7.21.6.1 La fonction fprintf (p: 309-316)
  • 7.21.6.3 La fonction printf (p: 324)
  • 7.21.6.5 La fonction snprintf (p: 325)
  • 7.21.6.6 La fonction sprintf (p: 325-326)
  • K.3.5.3.1 La fonction fprintf_s (p: 591)
  • K.3.5.3.3 La fonction printf_s (p: 593-594)
  • K.3.5.3.5 La fonction snprintf_s (p: 594-595)
  • K.3.5.3.6 La fonction sprintf_s (p: 595-596)
  • Norme C99 (ISO/CEI 9899:1999) :
  • 7.19.6.1 La fonction fprintf (p : 274-282)
  • 7.19.6.3 La fonction printf (p : 290)
  • 7.19.6.5 La fonction snprintf (p : 290-291)
  • 7.19.6.6 La fonction sprintf (p : 291)
  • Norme C89/C90 (ISO/CEI 9899:1990) :
  • 4.9.6.1 La fonction fprintf
  • 4.9.6.3 La fonction printf
  • 4.9.6.5 La fonction sprintf

Voir aussi

imprime une sortie formatée de caractères larges vers stdout , un flux de fichier ou un tampon
(fonction)
imprime une sortie formatée vers stdout , un flux de fichier ou un tampon
en utilisant une liste d'arguments variables
(fonction)
écrit une chaîne de caractères dans un flux de fichier
(fonction)
lit une entrée formatée depuis stdin , un flux de fichier ou un tampon
(fonction)
Documentation C++ pour printf , fprintf , sprintf , snprintf