std:: btowc
|
Défini dans l'en-tête
<cwchar>
|
||
|
std::
wint_t
btowc
(
int
c
)
;
|
||
Élargit un caractère sur un octet c à son équivalent en caractère large.
La plupart des encodages de caractères multioctets utilisent des codes à un octet pour représenter les caractères du jeu de caractères ASCII. Cette fonction peut être utilisée pour convertir ces caractères en wchar_t .
Table des matières |
Paramètres
| c | - | caractère à un octet à élargir |
Valeur de retour
WEOF si c est EOF .
Représentation en caractère large de c si ( unsigned char ) c est un caractère mono-octet valide dans l'état de décalage initial, WEOF sinon.
Exemple
#include <clocale> #include <cwchar> #include <iostream> void try_widen(char c) { std::wint_t w = std::btowc(c); if (w != WEOF) std::cout << "The single-byte character " << +(unsigned char)c << " widens to " << +w << '\n'; else std::cout << "The single-byte character " << +(unsigned char)c << " failed to widen\n"; } int main() { std::setlocale(LC_ALL, "lt_LT.iso88594"); std::cout << std::hex << std::showbase << "In Lithuanian ISO-8859-4 locale:\n"; try_widen('A'); try_widen('\xdf'); // German letter ß (U+00df) in ISO-8859-4 try_widen('\xf9'); // Lithuanian letter ų (U+0173) in ISO-8859-4 std::setlocale(LC_ALL, "lt_LT.utf8"); std::cout << "In Lithuanian UTF-8 locale:\n"; try_widen('A'); try_widen('\xdf'); try_widen('\xf9'); }
Sortie possible :
In Lithuanian ISO-8859-4 locale: The single-byte character 0x41 widens to 0x41 The single-byte character 0xdf widens to 0xdf The single-byte character 0xf9 widens to 0x173 In Lithuanian UTF-8 locale: The single-byte character 0x41 widens to 0x41 The single-byte character 0xdf failed to widen The single-byte character 0xf9 failed to widen
Voir aussi
|
rétrécit un caractère large en un caractère étroit d'un seul octet, si possible
(fonction) |
|
|
[virtual]
|
convertit un ou plusieurs caractères de
char
vers
CharT
(fonction membre protégée virtuelle de
std::ctype<CharT>
)
|
|
Documentation C
pour
btowc
|
|