Sdílet prostřednictvím


printf, _printf_l, , wprintf_wprintf_l

Vytiskne formátovaný výstup do standardního výstupního datového proudu. K dispozici jsou bezpečnější verze těchto funkcí; viz printf_s, _printf_s_l, wprintf_s, _wprintf_s_l.

Syntaxe

int printf(
   const char *format [,
   argument]...
);
int _printf_l(
   const char *format,
   _locale_t locale [,
   argument]...
);
int wprintf(
   const wchar_t *format [,
   argument]...
);
int _wprintf_l(
   const wchar_t *format,
   _locale_t locale [,
   argument]...
);

Parametry

format
Formátovat ovládací prvek

argument
Volitelné argumenty

locale
Národní prostředí, které se má použít

Vrácená hodnota

Vrátí počet tištěných znaků nebo zápornou hodnotu, pokud dojde k chybě. Pokud format je NULL, je vyvolána neplatná obslužná rutina parametru, jak je popsáno v ověření parametru. Pokud je spuštění povoleno pokračovat, vrátí funkce hodnotu -1 a nastaví errno hodnotu EINVAL. Pokud EOF je v argumentu (0xFFFF) zjištěn argument, vrátí funkce hodnotu -1.

Informace o errno kódech chyb naleznete v tématu errno, _doserrno, _sys_errlist, a _sys_nerr.

Poznámky

Funkce printf formátuje a vytiskne řadu znaků a hodnot do standardního výstupního datového proudu. stdout Pokud argumenty následují za format řetězcem, format musí řetězec obsahovat specifikace určující výstupní formát argumentů. printf a fprintf chovají se identicky s tím rozdílem, že printf zapisuje výstup stdout spíše než do cíle typu FILE.

wprintfje širokoznační verze printfformat řetězce . wprintf a printf chovejte se stejně, pokud je datový proud otevřen v režimu ANSI. printf v současné době nepodporuje výstup do datového proudu UNICODE.

Verze těchto funkcí s příponou _l jsou shodné s tím rozdílem, že používají parametr národního prostředí předaný místo aktuálního národního prostředí vlákna.

Argument format se skládá z běžných znaků, řídicích sekvencí a specifikace formátu (pokud argumenty následují format). Běžné znaky a řídicí sekvence se zkopírují do stdout pořadí jejich vzhledu. Například řádek:

printf("Line one\n\t\tLine two\n");

vytvoří výstup:

Line one
        Line two

Specifikace formátu vždy začínají znakem procenta (%) a čtou se zleva doprava. Když printf narazí na první specifikaci formátu (pokud existuje), převede hodnotu prvního argumentu za format a odpovídajícím způsobem ji vypíše. Druhá specifikace formátu způsobí, že druhý argument bude převeden a výstup atd. Pokud existuje více argumentů, než jsou specifikace formátu, budou nadbytečné argumenty ignorovány. Výsledky nejsou definovány, pokud pro všechny specifikace formátu není dostatek argumentů.

Důležité

Ujistěte se, že format není uživatelem definovaný řetězec.

Mapování rutin obecného textu

Tchar.h rutina _UNICODE a _MBCS není definován _MBCS definovaný _UNICODE definovaný
_tprintf printf printf wprintf
_tprintf_l _printf_l _printf_l _wprintf_l

Požadavky

Rutina Požadovaný hlavičkový soubor
printf, _printf_l <stdio.h>
wprintf, _wprintf_l <stdio.h> nebo <wchar.h>

Konzola není podporována v aplikacích pro Univerzální platforma Windows (UPW). Standardní zpracování datových proudů, které jsou přidružené ke konzole , a , stderrmusí být přesměrovány před tím, stdinstdoutnež je funkce runtime jazyka C mohou používat v aplikacích pro UPW. Další informace o kompatibilitě najdete v tématu Kompatibilita.

Důležité

Počínaje Windows 10 verze 2004 (build 19041) printf vytiskne řada funkcí přesně reprezentovatelná čísla s plovoucí desetinnou čárkou podle pravidel IEEE 754 pro zaokrouhlování. V předchozích verzích Windows by se vždy zaokrouhlila přesně reprezentovatelná čísla s plovoucí desetinnou čárkou končící na 5. IEEE 754 uvádí, že musí zaokrouhlit na nejbližší sudou číslici (označované také jako "Zaokrouhlování bankera"). Například obě printf("%1.0f", 1.5) a printf("%1.0f", 2.5) měly by se zaokrouhlit na 2. Dříve by se 1,5 zaokrouhlo na 2 a 2,5 by se zaokrouhlilo na 3. Tato změna má vliv jenom na přesně reprezentovatelná čísla. Například hodnota 2,35 (která je při znázornění v paměti blíže 2,350000000000008) pokračuje zaokrouhlit nahoru na 2,4. Zaokrouhlování provedené těmito funkcemi nyní respektuje také režim zaokrouhlování s plovoucí desetinou čárkou nastavený .fesetround Dříve bylo zaokrouhlení vždy zvoleno FE_TONEAREST chování. Tato změna má vliv jenom na programy vytvořené pomocí sady Visual Studio 2019 verze 16.2 a novější. Chcete-li použít starší chování zaokrouhlování s plovoucí desetinou čárkou, propojte s legacy_stdio_float_rounding.obj.

Příklad

// crt_printf.c
// This program uses the printf and wprintf functions
// to produce formatted output.

#include <stdio.h>

int main( void )
{
   char     ch = 'h',
            *string = "computer";
   wchar_t  wch = L'w',
            *wstring = L"Unicode";
   int      count = -9234;
   double   fp = 251.7366;

   // Display integers
   printf( "Integer formats:\n"
           "   Decimal: %d  Justified: %.6d  "
           "Unsigned: %u\n",
           count, count, count, count );

   // Display decimals
   printf( "Decimal %d as:\n   Hex: %Xh  "
           "C hex: 0x%x  Octal: %o\n",
            count, count, count, count );

   // Display in different radixes
   printf( "Digits 10 equal:\n   Hex: %i  "
           "Octal: %i  Decimal: %i\n",
            0x10, 010, 10 );

   // Display characters
   printf("Characters in field (1):\n"
          "%10c%5hc%5C%5lc\n",
          ch, ch, wch, wch);
   wprintf(L"Characters in field (2):\n"
           L"%10C%5hc%5c%5lc\n",
           ch, ch, wch, wch);

   // Display strings
   printf("Strings in field (1):\n%25s\n"
          "%25.4hs\n   %S%25.3ls\n",
          string, string, wstring, wstring);
   wprintf(L"Strings in field (2):\n%25S\n"
           L"%25.4hs\n   %s%25.3ls\n",
           string, string, wstring, wstring);

   // Display real numbers
   printf("Real numbers:\n   %f %.2f %e %E\n",
          fp, fp, fp, fp );

   // Display pointer
   printf( "\nAddress as:   %p\n", &count);
}

Ukázkový výstup

Integer formats:
   Decimal: -9234  Justified: -009234  Unsigned: 4294958062
Decimal -9234 as:
   Hex: FFFFDBEEh  C hex: 0xffffdbee  Octal: 37777755756
Digits 10 equal:
   Hex: 16  Octal: 8  Decimal: 10
Characters in field (1):
         h    h    w    w
Characters in field (2):
         h    h    w    w
Strings in field (1):
                 computer
                     comp
   Unicode                      Uni
Strings in field (2):
                 computer
                     comp
   Unicode                      Uni
Real numbers:
   251.736600 251.74 2.517366e+002 2.517366E+002

Address as:   0012FF3C

Viz také

Syntaxe specifikace formátu: printf a wprintf funkce
Podpora pro matematiku a plovoucí desetinou čárku
Vstupně-výstupní operace streamu
Národní prostředí
fopen, _wfopen
_fprintf_p, _fprintf_p_l, , _fwprintf_p_fwprintf_p_l
scanf, _scanf_l, , wscanf_wscanf_l
sprintf, _sprintf_l, swprintf, , _swprintf_l__swprintf_l
vprintf – funkce
_set_output_format