Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Schreiben Sie formatierte Ausgaben mithilfe eines Zeigers auf eine Liste von Argumenten, mit der Möglichkeit, die Reihenfolge anzugeben, in der die Argumente verwendet werden.
Syntax
int _vsprintf_p(
char *buffer,
size_t sizeInBytes,
const char *format,
va_list argptr
);
int _vsprintf_p_l(
char *buffer,
size_t sizeInBytes,
const char *format,
_locale_t locale,
va_list argptr
);
int _vswprintf_p(
wchar_t *buffer,
size_t count,
const wchar_t *format,
va_list argptr
);
int _vswprintf_p_l(
wchar_t *buffer,
size_t count,
const wchar_t *format,
_locale_t locale,
va_list argptr
);
Die Parameter
buffer
Speicherort für die Ausgabe.
sizeInBytes
Größe von buffer
in Zeichen.
count
Maximale Anzahl von Zeichen, die in der UNICODE-Version dieser Funktion gespeichert werden sollen.
format
Format-Spezifikation.
argptr
Zeiger auf eine Liste von Argumenten.
locale
Das zu verwendende Gebietsschema.
Rückgabewert
_vsprintf_p
und _vswprintf_p
geben Sie die Anzahl der geschriebenen Zeichen ohne das abschließende NULL
Zeichen oder einen negativen Wert zurück, wenn ein Ausgabefehler auftritt.
Wenn die buffer
ein Zeiger ist NULL
und sizeInBytes
oder count
Null sind, geben Funktionen die Anzahl der Zeichen zurück, die ohne das abschließende NULL
geschrieben worden wären.
Wenn der buffer
gültig ist und sizeInBytes
/oder count
null ist, wird -1 zurückgegeben.
Bemerkungen
Jede dieser Funktionen verwendet einen Zeiger auf eine Argumentliste und formatiert dann die angegebenen Daten und schreibt sie in den Speicher, auf den mit buffer
zeigt.
Diese Funktionen unterscheiden sich von den vsprintf_s
und vswprintf_s
nur dadurch, dass sie Positionsparameter unterstützen. Weitere Informationen finden Sie unter printf_p Positionsparametern.
Die Versionen dieser Funktionen mit dem _l
Suffix sind identisch, mit der Ausnahme, dass sie den übergebenen locale-Parameter anstelle des aktuellen Thread-Gebietsschemas verwenden.
Wenn es sich bei den oder-Parametern buffer
format
um Zeiger handelt NULL
oder wenn die Formatzeichenfolge ungültige Formatierungszeichen enthält, wird der Handler für ungültige Parameter aufgerufen, wie unter Parameterüberprüfung beschrieben. Wenn die Ausführung fortgesetzt werden darf, geben die Funktionen -1 zurück und setzen errno
auf EINVAL
.
Von Bedeutung
Ab Windows 10 Version 2004 (Build 19041) druckt die printf
Funktionsfamilie exakt darstellbare Gleitkommazahlen gemäß den IEEE 754-Regeln für die Rundung. In früheren Versionen von Windows wurden genau darstellbare Gleitkommazahlen, die auf "5" endeten, immer aufgerundet. IEEE 754 besagt, dass sie auf die nächste gerade Ziffer runden müssen (auch bekannt als "Banker's Rounding"). Zum Beispiel sollte sowohl als auch printf("%1.0f", 1.5)
printf("%1.0f", 2.5)
auf 2 gerundet werden. Zuvor wurde 1,5 auf 2 und 2,5 auf 3 gerundet. Diese Änderung betrifft nur exakt darstellbare Zahlen. Beispiel: 2,35 (das, wenn es im Speicher dargestellt wird, näher an 2,350000000000000008 liegt) rundet weiter auf 2,4 auf. Die Rundung, die von diesen Funktionen durchgeführt wird, berücksichtigt nun auch den von festgelegten Gleitkomma-Rundungsmodus fesetround
. Zuvor wählte die Rundung immer das Verhalten aus FE_TONEAREST
. Diese Änderung betrifft nur Programme, die mit Visual Studio 2019 Version 16.2 und höher erstellt wurden. Um das alte Gleitkomma-Rundungsverhalten zu verwenden, verknüpfen Sie mit 'legacy_stdio_float_rounding.obj'.
Mapping generischer Textroutinen
TCHAR.H-Routine |
_UNICODE und _MBCS nicht definiert |
_MBCS definiert |
_UNICODE definiert |
---|---|---|---|
_vstprintf_p |
_vsprintf_p |
_vsprintf_p |
_vswprintf_p |
_vstprintf_p_l |
_vsprintf_p_l |
_vsprintf_p_l |
_vswprintf_p_l |
Anforderungen
Routine | Erforderlicher Header | Optionale Header |
---|---|---|
_vsprintf_p , _vsprintf_p_l |
<stdio.h> und <stdarg.h> | <varargs.h>* |
_vswprintf_p , _vswprintf_p_l |
<stdio.h> oder <wchar.h> und <stdarg.h> | <varargs.h>* |
* Erforderlich für UNIX V-Kompatibilität.
Weitere Informationen zur Kompatibilität finden Sie unter Kompatibilität.
Beispiel
// crt__vsprintf_p.c
// This program uses vsprintf_p to write to a buffer.
// The size of the buffer is determined by _vscprintf_p.
#include <stdlib.h>
#include <stdio.h>
#include <stdarg.h>
void example( char * format, ... )
{
va_list args;
int len;
char *buffer = NULL;
va_start( args, format );
// _vscprintf doesn't count the
// null terminating string so we add 1.
len = _vscprintf_p( format, args ) + 1;
// Allocate memory for our buffer
buffer = (char*)malloc( len * sizeof(char) );
if (buffer)
{
_vsprintf_p( buffer, len, format, args );
puts( buffer );
free( buffer );
}
va_end( args );
}
int main( void )
{
// First example
example( "%2$d %1$c %3$d", '<', 123, 456 );
// Second example
example( "%s", "This is a string" );
}
123 < 456
This is a string
Siehe auch
Stream-E/A
vprintf
-Funktionen
Syntax der Formatspezifikation: printf
und wprintf
Funktionen
fprintf
, , _fprintf_l
fwprintf
_fwprintf_l
printf
, , _printf_l
wprintf
_wprintf_l
sprintf
, _sprintf_l
, swprintf
, _swprintf_l
, __swprintf_l
va_arg
, , va_copy
va_end
va_start