Printf
Author
Albert Floresprintf je funkce v programovacím jazyce C, která provádí formátovaný výpis dat v textové podobě.
Funkce má proměnný počet parametrů a na standardní výstup vypíše textový řetězec zadaný prvním parametrem, v němž jsou formátovací direktivy nahrazeny hodnotami dalších parametrů. Použitý způsob formátování byl převzat do mnoha dalších programovacích jazyků a některé unixové shelly obsahují stejně pojmenovaný příkaz pro formátovaný výpis dat.
Příklad použití
printf("Dnes je %s %d. %s %d; teplota je %+.1f stupňů Celsia.\n", dny_v_tydnu[dt], den, mesice[mesic], rok, teplota);
může vypsat
Dnes je středa 11. července 2018; teplota je +20.5 stupňů Celsia.
s odřádkováním na konci.
Příbuzné funkce
Ve standardní knihovně jazyka C je několik podobných funkcí deklarovaných v hlavičkovém souboru stdio.h:
* printf - pro formátovaný výpis na standardní výstup * fprintf - pro formátovaný výstup do libovolného souboru, resp. datového proudu otevřeného pro výstup * sprintf - ukládá výstup do řetězce * snprintf - ukládá výstup do řetězce omezené délky
Dále existují varianty pro výstup řetězců v kódování UTF-32 složených ze znaků wide char (typu wchar_t); tyto funkce mají ve jméně wprintf místo printf, a funkce deklarované v hlavičkovém souboru stdarg.h, jimž se volitelné parametry předávají pomocí struktury va_list, jejichž jména začínají písmenem v - například funkce vswprintf ukládá výstup zadaný strukturou va_list a formátovacím řetězcem typu wchar_t * a do řetězce téhož typu omezené délky (varianty pro wide char pracují vždy s řetězci omezené délky a jejich jména místo sn obsahují pouze sw).
Všechny uvedené funkce vracejí počet zapsaných znaků nebo zápornou hodnotu v případě chyby.
Podobnou filozofii mají funkce řady scanf, které provádějí naopak vstupní konverzi.
Formátovací řetězec
Jedním z parametrů všech uvedených funkcí je formátovací řetězec, který může obsahovat sekvence pro výpis řídicích znaků začínající znakem zpětné lomítko (\) a formátovací direktivy začínající znakem procento (%).
Syntaxe
Syntaxe formátovacích direktiv je následující:
:%[číslo parametru][příznaky][šířka][.přesnost][velikost]typ
Typ
Jako typ lze použít některý z níže uvedených znaků:
:
Typ | Parametr | Význam |
---|---|---|
% | (žádný) | vypíše znak % |
d, i | celočíselný | vypíše číslo v desítkové soustavě se znaménkem |
u | celočíselný | vypíše číslo v desítkové soustavě bez znaménka |
f, F | double | vypíše číslo ve formátu s pohyblivou řádovou tečkou; malé a velké f se liší pouze ve způsobu výpisu nekonečna a chybného čísla (pro f se vypisuje inf, infinity a nan; pro F INF, INFINITY a NAN) |
e, E | double | vypíše hodnotu v semilogaritmickém tvaru ([-]d. ddd e[+/-]ddd); podle použitého písmena bude E ve výpisu malé nebo velké; exponent má vždy nejméně dvě číslice; pro nulu je exponent 00; ve Windows má exponent implicitně tři číslice, tj. +more 1. 5e002, lze změnit funkcí _set_output_format dostupnou v systémech Microsoftu |
g, G | double | vypíše hodnotu jako kratší z řetězců získaných formáty f, F nebo e, E; na rozdíl od celočíselných formátů se nevypisují nevýznamné nuly |
x, X | celočíselný | vypíše číslo v šestnáctkové soustavě bez znaménka, číslice 10 až 15 se pro typ x vypisují malými písmeny a, b, c, d, e, f, pro typ X velkými písmeny A, B, C, D, E, F |
o | celočíselný | vypíše číslo v osmičkové soustavě bez znaménka |
s | char * | vypíše řetězec |
c | char | vypíše znak |
p | void * | vypíše adresu |
a, A | double | vypíše obsah bytů v šestnáctkovém zápise začínajícím 0x nebo 0X [url=http://www. cplusplus. com/reference/cstdio/printf/]"printf"[/url] (%a přidáno v C99) (v C++11 iostreams funguje stejně hexfloat). |
n | ukazatel na int | Nic nevypisuje, ale do příslušného parametru uloží počet dosud vypsaných znaků (v rámci tohoto vyvolání printf Java: indikuje platformně neutrální znak konce řádku Poznámka: tento parametr může být zneužit při útocích Uncontrolled format string |
Velikost
Pole velikost udává přesný typ příslušného parametru:
:
Velikost | Význam |
---|---|
hh | Pro celočíselný formát je použit parametr typu char. |
h | Pro celočíselný formát je použit parametr typu short. +more |
l | Pro celočíselný formát je použit parametr typu long. Pro formát s pohyblivou řádovou čárkou nemá žádný efekt. |
ll | Pro celočíselný formát je použit parametr typu long long. |
L | Pro formát s pohyblivou řádovou čárkou je použit parametr typu long double. |
z | Pro celočíselný formát je použit parametr typu size_t. |
j | Pro celočíselný formát je použit parametr typu intmax_t. |
t | Pro celočíselný formát je použit parametr typu ptrdiff_t. |
Přesnost
U formátů s pohyblivou řádovou čárkou udává, na kolik desetinných míst má být výpis čísla zaokrouhlen; u řetězců udává maximální počet znaků, které mají být vypsány.
Pole může být vynecháno, může být zadáno číslem, nebo hvězdičkou; hvězdička znamená, že hodnota je zadána parametrem typu int. Např. printf("%.*s", 3, "abcdef") vypíše abc
Šířka
Šířka udává minimální počet znaků, které mají být vypsány; pokud by byl výstup kratší bude doplněn mezerami (přesný způsob závisí na použitých příznacích). Pole šířka nikdy nezpůsobí zkrácení výpisu.
Zadání šířky může být vynecháno, může být použito číslo, nebo hvězdička; hvězdička znamená, že hodnotu udává další parametr typu int
Např. printf("%0*d", 5, 10) vypíše 00010.
Příznaky
Je možné použít žádný, jeden nebo více příznaků v libovolném pořadí: :
Příznak | Význam |
---|---|
- (minus) | zarovnat vlevo, vpravo doplnit mezerami |
+ (plus) | před číslem vždy vypsat znaménko (i plus) |
(mezera) | před záporným číslem vypsat -, před kladným mezeru |
# (hash) | použít alternativní formát výpisu: pro typ o vypisovat před nenulové číslo 0 pro typ x vypisovat před číslo 0x pro typ X vypisovat před číslo 0X pro typy e, E, f a F vždy psát desetinnou tečku pro typy g a G vždy psát tečku, neusekávat koncové nuly |
0 (nula) | Pokud je použito pro numerický typ a je zadána šířka, doplní číslo na zadanou šířku zleva nulami; zatímco printf("%2X",3) vypíše 3, tak printf("%02X",3) vypíše 03. |
Číslo parametru
Číslo parametru je rozšíření POSIX, které není obsaženo v normě C99. Používá se například při lokalizaci softwaru, když je potřeba změnit pořadí slov zadaných jako parametry. +more Pokud je číslo parametru použito v jedné formátovací direktivě, musí být použito u všech v daném volání printf. Jeho tvar je:.
:
Hodnota | Význam |
---|---|
n$ | n je číslo parametru, který má být vypsán touto formátovací direktivou; opakováním téhož čísla je možné vypsat jeden parametr vícekrát i s použitím různých formátů Např. printf("%2$d (%2$x hex); %1$d (%1$x hex)",16,17) vypíše 17 (11 hex); 16 (10 hex). +more |