uint8_t zachowanie iostream

Streszczenie: Spodziewałem się kodu: cout << uint8_t (0); wydrukować „0”, ale nic nie drukuje.

Wersja długa: Kiedy próbuję przesyłać strumieniowo obiekty uint8_t do cout, otrzymuję dziwne znaki z gcc. Czy to oczekiwane zachowanie? Czy to możliwe, że uint8_t jest aliasem dla jakiegoś typu opartego na znakach? Zobacz uwagi kompilatora / systemu w przykładzie kodu.

// compile and run with:
// g++ test-uint8.cpp -std=c++11 && ./a.out
//                    -std=c++0x (for older gcc versions)
/**
 * prints out the following with compiler:
 *     gcc (GCC) 4.7.2 20120921 (Red Hat 4.7.2-2)
 * on the system:
 *     Linux 3.7.9-101.fc17.x86_64
 * Note that the first print statement uses an unset uint8_t
 * and therefore the behaviour is undefined. (Included here for
 * completeness)

> g++ test-uint8.cpp -std=c++11 && ./a.out
>>>�<<<    >>>194<<<
>>><<<    >>>0<<<
>>><<<    >>>0<<<
>>><<<    >>>0<<<
>>><<<    >>>1<<<
>>><<<    >>>2<<<

 *
 **/

#include <cstdint>
#include <iostream>

void print(const uint8_t& n)
{
    std::cout << ">>>" << n                 << "<<<    "
              << ">>>" << (unsigned int)(n) << "<<<\n";
}

int main()
{
    uint8_t a;
    uint8_t b(0);
    uint8_t c = 0;
    uint8_t d{0};
    uint8_t e = 1;
    uint8_t f = 2;
    for (auto i : {a,b,c,d,e,f})
    {
        print(i);
    }
}

questionAnswers(3)

yourAnswerToTheQuestion