Funcția vfwprintf () din C ++ este utilizată pentru a scrie un șir larg formatat într-un flux de fișiere.
Funcția vfwprintf () este definită în fișierul antet.
prototip vfwprintf ()
int vfwprintf (FILE * stream, const wchar_t * format, va_list vlist);
Funcția vfwprintf () scrie șirul larg indicat în funcție de format în fluxul de flux de fișiere. Formatul șirului larg poate conține specificatori de format începând cu%, care sunt înlocuiți cu valorile variabilelor care sunt trecute ca listă vlist.
vfwprintf () Parametri
- stream: flux de fișiere de ieșire pentru a scrie rezultatul.
- format: un pointer către un șir larg terminat nul, care este scris în flux. Se compune din caractere împreună cu specificatori de format opționali începând cu%. Specificatorii de format sunt înlocuiți cu valorile variabilelor respective care urmează formatului.
Specificatorul de format are următoarele părți:- Un semn de conducere%
- Semnalizări: opțional unul sau mai multe semnalizatoare care modifică comportamentul de conversie.
- -: Stânga justifică rezultatul în câmp. În mod implicit, este justificat.
- +: Semnul rezultatului este atașat la începutul valorii, chiar și pentru rezultate pozitive.
- Spațiu: dacă nu există niciun semn, un spațiu este atașat la începutul rezultatului.
- #: Se efectuează o formă alternativă de conversie.
- 0: Se folosește pentru numărul întreg și numărul cu virgulă mobilă. Zero-urile principale sunt utilizate pentru a tampona numerele în loc de spațiu.
- Lățime: o valoare opțională * sau întreagă utilizată pentru a specifica câmpul de lățime minimă.
- Precizie: un câmp opțional format dintr-un. urmat de * sau întreg sau nimic pentru a specifica precizia.
- Lungime: un modificator opțional de lungime care specifică dimensiunea argumentului.
- Specificator: un specificator de format de conversie. Specificatorii de format disponibili sunt după cum urmează:
Specificator de format Descriere % % Tipăriri c Scrie un singur personaj s Scrie un șir de caractere d sau i Convertește un număr întreg semnat în reprezentare zecimală o Convertește un număr întreg nesemnat în reprezentare octală X sau x Convertește un număr întreg nesemnat în reprezentare hexazecimală tu Convertește un număr întreg nesemnat în reprezentare zecimală F sau f Convertește numărul în virgulă mobilă în reprezentarea zecimală E sau e Convertește numărul în virgulă mobilă în notația exponentului zecimal A sau a Convertește numărul în virgulă mobilă în exponentul hexazecimal G sau g Convertește numărul în virgulă mobilă fie în notație zecimală, fie în exponentă zecimală n Returnează numărul de caractere scrise până acum de acest apel către funcție. Rezultatul este scris la valoarea indicată de argument p Scrie o secvență de caractere definită de implementare care definește un pointer.
Deci, formatul general al specificatorului de format este:% (steaguri) (lățime) (. precizie) (lungime) specificator
- vlist: o listă de argumente care conțin datele de scris.
vfwprintf () Valoare returnată
- Dacă are succes, funcția vfwprintf () returnează numărul de caractere largi scrise.
- La eșec, returnează o valoare negativă.
Exemplu: Cum funcționează funcția vfwprintf ()?
#include #include #include void write(const wchar_t *fmt,… ) ( va_list args; va_start(args, fmt); vfwprintf(fmt, args); va_end(args); ) int main () ( wchar_t desc(5)(10) = (L"Eta",L"Theta",L"Iota",L"Kappa",L"Lamda"); int x = 0; setlocale(LC_ALL, "en_US.UTF-8"); wprintf(L"Some Greek Letters"); for (wchar_t i=L'u03b7'; i<=L'u03bb'; i++) ( write(L"%ls : %lc", desc(x), i); x++; ) return 0; )
Când rulați programul, următoarele vor fi scrise în example.txt:
Câteva litere grecești Eta: η Theta: θ Iota: ι Kappa: κ Lamda: λ