printf_s
, _printf_s_l
, , wprintf_s
_wprintf_s_l
Vytiskne formátovaný výstup do standardního výstupního datového proudu. Tyto verze printf
, , _printf_l
_wprintf_l
wprintf
mají vylepšení zabezpečení, jak je popsáno v funkcích zabezpečení v CRT.
Syntaxe
int printf_s(
const char *format [,
argument]...
);
int _printf_s_l(
const char *format,
_locale_t locale [,
argument]...
);
int wprintf_s(
const wchar_t *format [,
argument]...
);
int _wprintf_s_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ě.
Poznámky
Funkce printf_s
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ů.
Hlavním rozdílem mezi printf_s
formátovacím řetězcem a printf
je, že printf_s
kontroluje platné znaky formátování, zatímco printf
pouze kontroluje, zda je formátovací řetězec ukazatelem null. Pokud se některé z kontrol nezdaří, vyvolá se 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
.
Informace o errno
kódech chyb naleznete v tématu errno
, _doserrno
, _sys_errlist
, a _sys_nerr
.
printf_s
a fprintf_s
chovají se identicky s tím rozdílem, že printf_s
zapisuje výstup stdout
spíše než do cíle typu FILE
. Další informace naleznete v tématu fprintf_s
, _fprintf_s_l
, fwprintf_s
, _fwprintf_s_l
.
wprintf_s
je širokoznační verze printf_s
format
řetězce . wprintf_s
a printf_s
chovejte se stejně, pokud je datový proud otevřen v režimu ANSI. printf_s
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.
Mapování rutin obecného textu
TCHAR.H rutina |
_UNICODE a _MBCS není definován |
_MBCS definovaný |
_UNICODE definovaný |
---|---|---|---|
_tprintf_s |
printf_s |
printf_s |
wprintf_s |
_tprintf_s_l |
_printf_s_l |
_printf_s_l |
_wprintf_s_l |
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_s("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_s
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.
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
.
Požadavky
Rutina | Požadovaný hlavičkový soubor |
---|---|
printf_s , _printf_s_l |
<stdio.h> |
wprintf_s , _wprintf_s_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 , stderr
musí být přesměrovány před tím, stdin
stdout
než je funkce runtime jazyka C mohou používat v aplikacích pro UPW. Další informace o kompatibilitě najdete v tématu Kompatibilita.
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 , stderr
musí být přesměrovány před tím, stdin
stdout
než je funkce runtime jazyka C mohou používat v aplikacích pro UPW. Další informace o kompatibilitě najdete v tématu Kompatibilita.
Příklad
// crt_printf_s.c
/* This program uses the printf_s and wprintf_s functions
* to produce formatted output.
*/
#include <stdio.h>
int main( void )
{
char ch = 'h', *string = "computer";
int count = -9234;
double fp = 251.7366;
wchar_t wch = L'w', *wstring = L"Unicode";
/* Display integers. */
printf_s( "Integer formats:\n"
" Decimal: %d Justified: %.6d Unsigned: %u\n",
count, count, count );
printf_s( "Decimal %d as:\n Hex: %Xh C hex: 0x%x Octal: %o\n",
count, count, count, count );
/* Display in different radixes. */
printf_s( "Digits 10 equal:\n Hex: %i Octal: %i Decimal: %i\n",
0x10, 010, 10 );
/* Display characters. */
printf_s("Characters in field (1):\n%10c%5hc%5C%5lc\n", ch, ch, wch, wch);
wprintf_s(L"Characters in field (2):\n%10C%5hc%5c%5lc\n", ch, ch, wch, wch);
/* Display strings. */
printf_s("Strings in field (1):\n%25s\n%25.4hs\n %S%25.3ls\n",
string, string, wstring, wstring);
wprintf_s(L"Strings in field (2):\n%25S\n%25.4hs\n %s%25.3ls\n",
string, string, wstring, wstring);
/* Display real numbers. */
printf_s( "Real numbers:\n %f %.2f %e %E\n", fp, fp, fp, fp );
/* Display pointer. */
printf_s( "\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: 0012FF78
Viz také
Podpora pro matematiku a plovoucí desetinou čárku
Vstupně-výstupní operace streamu
Národní prostředí
fopen
, _wfopen
fprintf
, _fprintf_l
, , fwprintf
_fwprintf_l
scanf
, _scanf_l
, , wscanf
_wscanf_l
sprintf
, _sprintf_l
, swprintf
, , _swprintf_l
__swprintf_l
vprintf
– funkce