我有一个关于在c++中处理整数的奇怪问题。

我写了一个简单的程序,将一个值设置为一个变量,然后打印它,但它不像预期的那样工作。

我的程序只有两行代码:

uint8_t aa = 5;

cout << "value is " << aa << endl;

这个程序的输出是value is

也就是说,它为aa打印空白。

当我把uint8_t改为uint16_t时,上面的代码就像一个魅力。

我使用Ubuntu 12.04 (Precise Pangolin), 64位,我的编译器版本是:

gcc version 4.6.3 (Ubuntu/Linaro 4.6.3-1ubuntu5)

当前回答

cout将aa作为ASCII值5的char,这是一个不可打印的字符,在打印之前尝试类型转换为int。

其他回答

正如其他人之前所说,问题发生是因为标准流将signed char和unsigned char视为单个字符,而不是数字。

以下是我对代码修改最少的解决方案:

uint8_t aa = 5;

cout << "value is " << aa + 0 << endl;

添加“+0”对包括浮点数在内的任何数字都是安全的。

对于整型,如果sizeof(aa) < sizeof(int),则将结果类型更改为int。如果sizeof(aa) >= sizeof(int),它不会改变类型。

这个解决方案也适用于准备将int8_t打印到流中,而其他一些解决方案则不太好:

int8_t aa = -120;

cout << "value is " << aa + 0 << endl;
cout << "bad value is " << unsigned(aa) << endl;

输出:

value is -120
bad value is 4294967176

P.S.由pepper_chico和π α νταῥεῖ给出的带有ADL的解真的很漂亮。

它并不真正打印一个空白,但很可能是值为5的ASCII字符,这是不可打印的(或不可见的)。有很多不可见的ASCII字符代码,大多数都低于32,也就是空白。

必须将aa转换为unsigned int才能输出数值,因为ostream& operator<<(ostream&, unsigned char)尝试输出可见字符值。

uint8_t aa=5;

cout << "value is " << unsigned(aa) << endl;

cout将aa作为ASCII值5的char,这是一个不可打印的字符,在打印之前尝试类型转换为int。

Uint8_t很可能是unsigned char的类型定义。ostream类对unsigned char有一个特殊的重载,即它打印带有数字5的字符,这个字符是不可打印的,因此是空的。

std::ostream和char之间的操作符<<()重载是非成员函数。您可以显式地使用成员函数将char(或uint8_t)作为int处理。

#include <iostream>
#include <cstddef>

int main()
{
   uint8_t aa=5;

   std::cout << "value is ";
   std::cout.operator<<(aa);
   std::cout << std::endl;

   return 0;
}

输出:

value is 5