En C, le manipulateur de flux hexadécimal fournit un moyen pratique d'imprimer des entiers au format hexadécimal. Cet article explique comment créer un manipulateur de flux personnalisé qui modifie l'élément suivant du flux.
Plus précisément, nous visons à créer un manipulateur plus un qui incrémente la valeur du prochain entier imprimé de 1. Pour y parvenir, nous devons stocker un état dans chaque flux. On peut utiliser la fonction iword et un index alloué par xalloc à cet effet :
inline int geti() { static int i = ios_base::xalloc(); return i; } ostream& add_one(ostream& os) { os.iword(geti()) = 1; return os; } ostream& add_none(ostream& os) { os.iword(geti()) = 0; return os; }
Avec cet état en place, on peut le récupérer dans tous les flux. Pour nous connecter à l'opération de sortie qui effectue le formatage numérique, nous définissons une facette personnalisée :
struct my_num_put : num_put<char> { iter_type do_put(iter_type s, ios_base& f, char_type fill, long v) const { return num_put<char>::do_put(s, f, fill, v + f.iword(geti())); } iter_type do_put(iter_type s, ios_base& f, char_type fill, unsigned long v) const { return num_put<char>::do_put(s, f, fill, v + f.iword(geti())); } };
Cette facette ajoute la valeur stockée dans l'état du flux au nombre en cours d'impression.
Maintenant, nous pouvons tester le manipulateur plusone :
int main() { // outputs: 11121011 cout.imbue(locale(locale(),new my_num_put)); cout << add_one << 10 << 11 << add_none << 10 << 11; }
Ce code montre comment définir un manipulateur de flux personnalisé qui modifie l'élément suivant du flux. Pour garantir que seul l'élément suivant est incrémenté, nous pouvons réinitialiser l'état du flux à 0 après chaque appel do_put.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!