我有一个辅助函数,它接受一个固定长度的unsigned char数组,并将其作为格式化的char *返回。但是,我遇到了一些问题。
我试过
char* byteArrayToString(unsigned char byte[6]) {
char t[18] = {""};
char* str = t;
sprintf(str, "%02X:%02X:%02X:%02X:%02X:%02X", byte[0], byte[1], byte[2], byte[3], byte[4], byte[5]);
return str;
}
和
char* byteArrayToString(unsigned char byte[6]) {
std::string t = "";
char* str = t;
sprintf(str, "%02X:%02X:%02X:%02X:%02X:%02X", byte[0], byte[1], byte[2], byte[3], byte[4], byte[5]);
return str;
}
和
char* byteArrayToString(unsigned char byte[6]) {
char* str = new char();
sprintf(str, "%02X:%02X:%02X:%02X:%02X:%02X", byte[0], byte[1], byte[2], byte[3], byte[4], byte[5]);
return str;
}
第二个导致该字符串的值被改变的一些副作用。第一个最终给了我垃圾值和最后一个seg错误(但我无法弄清楚为什么)。
答案 0 :(得分:3)
正确的方法是将std::string
作为:
#include <sstream> //for std::ostringstream
#include <string> //for std::string
#include <iomanip> //for std::setw, std::setfill
std::string byteArrayToString(unsigned char byte[6])
{
std::ostringstream ss;
for(size_t i = 0 ; i < 5 ; ++i)
ss << "0X" << std::hex << std::setw(2) << std::setfill('0') << (int) byte[i] << ":";
ss << "0X" << std::hex << std::setw(2) << std::setfill('0') << (int) byte[5];
return ss.str();
}
在呼叫网站上,您可以获得const char*
:
std::string s = byteArrayToString(bytes);
const char *str = s.c_str();
答案 1 :(得分:3)
你的第一个问题不在于打印,而在于返回。您将返回一个指向已回收数组的指针(因为它是一个自动变量,它的生命周期在函数返回时结束)。
而是尝试:
string byteArrayToString(const unsigned char* const byte)
{
char t[18] = {""};
sprintf(t, "%02X:%02X:%02X:%02X:%02X:%02X", byte[0], byte[1], byte[2], byte[3], byte[4], byte[5]);
return t;
}