La fonction vsscanf () en C ++ est utilisée pour lire les données à partir d'un tampon de chaîne.
La fonction vsscanf () est définie dans le fichier d'en-tête.
prototype vsscanf ()
int vsscanf (const char * buffer, const char * format, va_list vlist);
La fonction vsscanf () lit les données dans la mémoire tampon de la chaîne de caractères et stocke les valeurs dans les emplacements respectifs définis par vlist.
Paramètres de vsscanf ()
- format: pointeur vers une chaîne de caractères terminée par null qui spécifie comment lire l'entrée. Il se compose de spécificateurs de format commençant par%.
La chaîne de format comprend les parties suivantes:- Caractères non blancs sauf% dont chacun consomme un caractère identique du flux d'entrée. Cela peut entraîner l'échec de la fonction si le caractère suivant du flux ne se compare pas.
- Caractère d'espacement: tous les caractères d'espacement consécutifs sont traités comme un seul caractère d'espacement. De plus, ' n', ' t' et '' sont considérés comme identiques.
- Spécification de conversion: elle suit le format suivant:
- Caractère% initial qui spécifie le début
- Un caractère facultatif * appelé de suppression d'affectation. Si ce caractère est présent, vsscanf () n'affecte le résultat à aucun argument de réception.
- Un nombre entier positif facultatif qui spécifie la largeur maximale du champ. Il spécifie le nombre maximum de caractères que vsscanf () est autorisé à consommer lors de la conversion spécifiée par la spécification de conversion actuelle.
- Un modificateur de longueur facultatif spécifiant la taille de l'argument de réception.
- Un spécificateur de format de conversion.
Spécificateur de format La description % Correspond au% littéral c Correspond à un ou plusieurs caractères. Si la largeur est définie, correspond exactement aux caractères de largeur. s Correspond aux caractères non blancs consécutifs. Si la largeur est définie, correspond exactement aux caractères de largeur ou jusqu'à ce que le premier espace soit trouvé. (ensemble) Correspond à une séquence non vide de caractères du jeu de caractères donné. Si est présent au début de l'ensemble, alors tous les caractères qui ne sont pas dans l'ensemble sont mis en correspondance. ré Correspond à un entier décimal. je Correspond à un entier. o Correspond à un entier octal non signé. X ou x Correspond à un entier hexadécimal non signé. u Correspond à un entier décimal non signé. A ou a, E ou e, F ou f, G ou g Correspond à un nombre à virgule flottante. n Renvoie le nombre de caractères lus jusqu'à présent. p Correspond à une séquence de caractères définie par l'implémentation définissant un pointeur.
Ainsi, le format général du spécificateur de format est:Spécificateur% (*) (largeur) (longueur)
- vlist: une liste d'arguments pour recevoir les entrées.
vsscanf () Valeur de retour
- En cas de succès, la fonction vsscanf () renvoie le nombre d'arguments lus avec succès.
- En cas d'échec, EOF est renvoyé.
Exemple: comment fonctionne la fonction vsscanf ()?
#include #include void read(const char* buf, const char * format,… ) ( va_list args; va_start (args, format); vsscanf (buf, format, args); va_end (args); ) int main () ( char buffer(100) = "Bruce Wayne Batman"; char fname(20), lname(20), superhero(20); read(buffer, "%s %s %s", fname, lname, superhero); printf("%s %s is %s.", fname, lname, superhero); return 0; )
Lorsque vous exécutez le programme, une sortie possible sera:
Bruce Wayne est Batman.