printf, fprintf, sprintf, snprintf, printf_s, fprintf_s, sprintf_s, snprintf_s
|
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 :
-
-
le spécificateur de conversion
%nest présent dans format -
un des arguments correspondant à
%sest 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_suniquement), la chaîne à stocker dans buffer (y compris le caractère nul final) dépasserait bufsz .
-
le spécificateur de conversion
-
Comme pour toutes les fonctions à vérification de limites,
printf_s,fprintf_s,sprintf_s, etsnprintf_sne 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.
-
introductoire
-
- (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)
valeur entière ou
-
-
(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)
-
- (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 .
|
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 .
|
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 .
|
signed
char
|
short
|
int
|
long
|
long
long
|
※
|
N/A | ||
o
|
Convertit un entier non signé en représentation octale oooo .
|
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 .
|
N/A | ||||||||
u
|
Convertit un entier non signé en représentation décimale dddd .
|
N/A | ||||||||
f
F
(C99)
|
Convertit un nombre à virgule flottante en notation décimale selon le format [-]ddd.ddd .
|
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.
|
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.
|
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 .
|
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.
|
signed
char
*
|
short
*
|
int
*
|
long
*
|
long
long
*
|
intmax_t
*
|
※
|
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
La valeur non numérique est convertie en
Les conversions
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
Le spécificateur de conversion d'écriture en mémoire
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
Si une spécification de conversion est invalide, le comportement est indéfini. |
||||||||||
Valeur de retour
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 :
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
|
(C95)
(C95)
(C95)
(C11)
(C11)
(C11)
(C11)
|
imprime une sortie formatée de caractères larges vers
stdout
, un flux de fichier ou un tampon
(fonction) |
|
(C99)
(C11)
(C11)
(C11)
(C11)
|
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) |
|
|
(C11)
(C11)
(C11)
|
lit une entrée formatée depuis
stdin
, un flux de fichier ou un tampon
(fonction) |
|
Documentation C++
pour
printf
,
fprintf
,
sprintf
,
snprintf
|
|