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>
.
中的一些工具
我在 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>
.