Here is a table summarizing what all the different conversions do:
Print an integer as a signed decimal number. See Integer Conversions, for details. ‘%d’ and ‘%i’ are synonymous for
output, but are different when used with scanf
for input
(see Table of Input Conversions).
Print an integer as an unsigned binary number. ‘%b’ uses lower-case ‘b’ with the ‘#’ flag and ‘%B’ uses upper-case. ‘%b’ is an ISO C23 feature; ‘%B’ is an optional ISO C23 feature. See Integer Conversions, for details.
Print an integer as an unsigned octal number. See Integer Conversions, for details.
Print an integer as an unsigned decimal number. See Integer Conversions, for details.
Print an integer as an unsigned hexadecimal number. ‘%x’ uses lower-case letters and ‘%X’ uses upper-case. See Integer Conversions, for details.
Print a floating-point number in normal (fixed-point) notation. ‘%f’ uses lower-case letters and ‘%F’ uses upper-case. See Floating-Point Conversions, for details.
Print a floating-point number in exponential notation. ‘%e’ uses lower-case letters and ‘%E’ uses upper-case. See Floating-Point Conversions, for details.
Print a floating-point number in either normal or exponential notation, whichever is more appropriate for its magnitude. ‘%g’ uses lower-case letters and ‘%G’ uses upper-case. See Floating-Point Conversions, for details.
Print a floating-point number in a hexadecimal fractional notation with the exponent to base 2 represented in decimal digits. ‘%a’ uses lower-case letters and ‘%A’ uses upper-case. See Floating-Point Conversions, for details.
Print a single character. See Other Output Conversions.
This is an alias for ‘%lc’ which is supported for compatibility with the Unix standard.
Print a string. See Other Output Conversions.
This is an alias for ‘%ls’ which is supported for compatibility with the Unix standard.
Print the value of a pointer. See Other Output Conversions.
Get the number of characters printed so far. See Other Output Conversions. Note that this conversion specification never produces any output.
Print the string corresponding to the value of errno
.
(This is a GNU extension.)
See Other Output Conversions.
Print a literal ‘%’ character. See Other Output Conversions.
If the syntax of a conversion specification is invalid, unpredictable things will happen, so don’t do this. If there aren’t enough function arguments provided to supply values for all the conversion specifications in the template string, or if the arguments are not of the correct types, the results are unpredictable. If you supply more arguments than conversion specifications, the extra argument values are simply ignored; this is sometimes useful.