博文链接:
以下是我根据博文修改格式出来的一个方法:
string* byteArray2HexStr(char* charArr, int len) {
string* strRetVal = new string();
for (int i = 0; i < len; i ++) {
char char1;
char char2;
int iVal = charArr[i];
int iVal1 = iVal / 16;
int iVal2 = iVal % 16;
if (iVal1 >= 0 && iVal1 <= 9) {
char1 = (char)(48 + iVal1);
} else {
char1 = (char)(55 + iVal1);
}
if (iVal2 >= 0 && iVal2 <= 9) {
char2 = (char)(48 + iVal2);
} else {
char2 = (char)(55 + iVal2);
}
*strRetVal = *strRetVal + char1 + char2;
}
return strRetVal;
}
刚找到这个东西的时候还是挺开心的,想到以后调试数据会方便些了。
没想到昨天在调一个 bug 的时候竟然中招了。
活生生将一个字节数组转换成了错误的十六进制字符串,然后我在做数据对比的时候,让我怀疑是在 bsd socket 的 recv() 方法出现了问题。
还特意发了一个帖子去向别人请教这个异常奇葩的问题:
详情请看帖子,其他就不多吐槽了,下面给出一个 “不可靠” 的例证:
#include <string>
#include <stdio.h>
#include "HexUtil.h"
using namespace std;
/**
* 执行结果为:
* e3 转换结果为:6*
*/
int main(int argc, const char * argv[]) {
int i = 0xE3;
unsigned char t_pArrChar[1];
t_pArrChar[0] = (unsigned char)i;
string* str = byteArray2HexStr(t_pArrChar, 1);
printf("%x 转换结果为:%s\n", i, str->c_str());
}
最后,总结一下:
网上现成的东西,自己拿过来用之前,要记得先做一下测试,检验一下牢固程度。