Funcția vsnprintf () din C ++ este utilizată pentru a scrie un șir formatat într-un buffer de șiruri.
Spre deosebire de vsprintf (), numărul maxim de caractere care pot fi scrise în buffer este specificat în vsnprintf()
.
prototip vsnprintf ()
int vsnprintf (char * buffer, size_t buf_size, const char format *, va_list vlist);
vsnprintf()
Funcția scrie șirul indicat de format într - un buffer șir de caractere. Numărul maxim de caractere care pot fi scrise este buf_size. După ce caracterele sunt scrise, se adaugă un caracter nul care se termină. Dacă buf_size este egal cu zero, nu se scrie nimic și tamponul poate fi un indicator nul.
Formatul șirului poate conține specificatori de format începând cu%, care sunt înlocuiți cu valorile variabilelor care sunt trecute ca listă vlist.
Este definit în fișierul antet.
vsnprintf () Parametri
- buffer: Pointer către un șir de caractere pentru a scrie rezultatul.
- buf_size: Numărul maxim de caractere de scris.
- format: Pointer către un șir terminat nul care este scris în fluxul de fișiere. 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ă șirului de format.
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:
%(flags)(width)(.precision)(length)specifier
- vlist: o listă de argumente care conțin datele de scris.
vsnprintf () Valoare returnată
- Dacă are succes,
vsnprintf()
funcția returnează numărul de caractere scrise. - La eșec, returnează o valoare negativă.
- Când lungimea șirului formatat este mai mare decât buf_size, trebuie tăiată. În astfel de cazuri,
vsnprintf()
funcția returnează numărul total de caractere, cu excepția caracterului nul final care ar fi fost scris, dacă limita buf_size nu a fost impusă.
Exemplu: Cum funcționează funcția vsnprintf ()
#include #include void write(char* buf, int buf_size, const char *fmt,… ) ( va_list args; va_start(args, fmt); vsnprintf(buf, buf_size, fmt, args); va_end(args); ) int main () ( char buffer(100); char fname(20) = "Bjarne"; char lname(20) = "Stroustrup"; char lang(5) = "C++"; write(buffer, 27, "%s was created by %s %s", lang, fname, lname); printf("%s", buffer); return 0; )
Când rulați programul, ieșirea va fi:
C ++ a fost creat de Bjarne