有时候我想看通信的报文内容,需要把它们按照十六进制打出来。每次都是上网查有点麻烦,所以把它记下来,这样方面以后查询
包含头文件#include <iomanip>
char sendData[]={1,2,3,4,5,6,7,8,9,0,11,12,12,23,43,54};
for(uint32_t i=0; i<sizeof(sendData); ++i)
{
std::cout<<std::hex<<std::setw(2)<<std::setfill('0')<<static_cast<int>(sendData[i])<<" ";
}
cout<<endl;
string receiveData(sendData, sizeof(sendData));
for(uint32_t i=0; i<receiveData.length(); ++i)
{
std::cout<<std::hex<<std::setw(2)<<std::setfill('0')<<static_cast<int>(receiveData.at(i))<<" ";
}
会输出这样的报文:
如果是QT,则
//输出十六进制字符串方法1
char srcData[]={2,24,54,6,60,0,24,45,0,13,05,30};
QString tempStrData;
for (unsigned long i=0; i<sizeof(srcData); ++i)
{
tempStrData += QString().sprintf("%02x ", srcData[i]);
}
qDebug()<<tempStrData;
tempStrData = "";
//输出十六进制字符串方法2
QString srcQS;
for (unsigned long i=0; i<sizeof(srcData); ++i)
{
srcQS.append(QChar(srcData[i]));
}
for (int i=0; i<srcQS.length(); ++i)
{
tempStrData += QString().sprintf("%02x ", srcQS.toUtf8().at(i));
}
qDebug()<<tempStrData;
结果为:
QByteArray按照16进制输出:
QByteArray srcData;
srcData.append((uint8_t)0x35);
srcData.append((uint8_t)0x00);
srcData.append((uint8_t)0x1D);
qDebug()<<srcData.toHex(' '); //中间用空格隔开
结果是:
"35 00 1d"
下面代码会将1234转成16进制大写输出,并添加0X前缀。
std::stringstream ioss; std::string stemp; ioss << std::setiosflags(ios::uppercase) << std::setiosflags(ios::showbase) << std::hex << 1234; ioss >> stemp; cout<<stemp<<endl;
如果不需要大写,则去掉std::setiosflags(ios::uppercase),如果不需要加0X前缀,则去掉std::setiosflags(ios::showbase)。
前面的设置更改了cout,如果想恢复到cout的原始状态,调用:
cout.unsetf(ios::fixed|ios::hex);
ios::fixed可以清除setfill()的设置,ios::hex可以清除hex设置。可以单独调用其中的某一个。