c++ std::cout 十六进制

c++ std::cout in hexadecimal

我在 C++ 中有一个带有 printf 的输出语句,如下所示:

for(int i=0; i<6; i++)
        printf("%.2X", (unsigned char) iter->hwaddress[i]);

我需要用std::cout做输出,我试过这样做:

for(int i=0; i<6; i++)
   cout << hex << (unsigned char) iter->hwaddress[i];

但这只是给了我:

  �:�:w:�:�:

有人知道怎么做吗?

您需要将其转换为 `int:

char c = 15;
cout << hex << setfill('0') << setw(2) << static_cast<int>(c); // prints "0f"

hex 仅影响整数 I/O,char 不被视为其中的一部分 - 因此您的代码最终仍会输出实际的 char

请注意,如果 char 已签名并且您需要它处理大于 0x7f 的值,您必须先将其转换为 unsigned char,然后再转换为 unsigned int:

cout << hex << setfill('0') << setw(2)
     << static_cast<unsigned int>(static_cast<unsigned char>(c));

不要转换为 unsigned char,而是转换为整数。

#include <iostream>
#include <iomanip>
#include <cstdio>

int
main()
{
  char numbers[] = {1, 2, 3, 4, 5, 6};
  // Using C-style printf:    
  for (int i = 0; i < 6; i++)
    std::printf("%02X", static_cast<unsigned>(numbers[i]));
  printf("\n");
  // Using C++ streams:
  for (int i = 0; i < 6; i++)
    std::cout << std::hex << std::setw(2) << std::setfill('0')
              << static_cast<unsigned>(numbers[i]);
  std::cout << std::endl;
}

<< 运算符在这些类型上重载。如果您完全需要转换,也请避免使用 C 风格的转换,转而使用 static_cast

如果那些 iter->hwaddress[i] 的值是硬件地址,您为什么不(重新解释_)将它们转换为实际指针?然后 cout 将以十六进制打印它们而无需任何额外的努力。

cout << reinterpret_cast<void*>(iter->hwaddress[i]);

不清楚是否需要固定位数。这可能需要 <iomanip>.

中的一些工具