Namespaces
Variants

std::wbuffer_convert<Codecvt,Elem,Tr>:: rdbuf

From cppreference.net
std:: streambuf * rdbuf ( ) const ;
(1)
std:: streambuf * rdbuf ( std:: streambuf * bytebuf ) ;
(2)
1) Devuelve el puntero al flujo de bytes subyacente.
2) Reemplaza el flujo de bytes asociado con bytebuf .

Valor de retorno

2) el valor anterior de bufptr

Ejemplo

#include <codecvt>
#include <iostream>
#include <locale>
#include <sstream>
int main()
{
    // Convertir UTF-8 a UCS4
    std::stringbuf utf8buf("z\u00df\u6c34\U0001d10b");
                       // o "\x7a\xc3\x9f\xe6\xb0\xb4\xf0\x9d\x84\x8b"
                       // o u8"zß水𝄋"
    std::wbuffer_convert<std::codecvt_utf8<wchar_t>> conv(&utf8buf);
    std::wistream ucsbuf(&conv);
    std::cout << "Leyendo desde un stringbuf UTF-8 mediante wbuffer_convert: "
              << std::hex << std::showbase;
    for (wchar_t c; ucsbuf.get(c);)
        std::cout << static_cast<std::wint_t>(c) << ' ';
    // Reutilizar el mismo wbuffer_convert para manejar salida UCS4 a UTF-8
    conv.rdbuf(std::cout.rdbuf());
    std::wostream out(&conv);
    std::cout << "\nEnviando datos UCS4 a std::cout mediante wbuffer_convert: ";
    out << L"z\u00df\u6c34\U0001d10b\n";
}

Salida:

Leyendo desde un stringbuf UTF-8 mediante wbuffer_convert: 0x7a 0xdf 0x6c34 0x1d10b 
Enviando datos UCS4 a std::cout mediante wbuffer_convert: zß水𝄋

Véase también

construye un nuevo wbuffer_convert
(función miembro pública)