32

我之前搜索char*hex字符串,但我发现实现时在字符串末尾添加了一些不存在的垃圾hex。我从套接字接收数据包,我需要将它们转换hex为日志字符串(空终止缓冲区)。有人可以建议我一个好的实施C++吗?

谢谢!

4

8 回答 8

34

假设数据是 char*。使用 std::hex 的工作示例:

for(int i=0; i<data_length; ++i)
    std::cout << std::hex << (int)data[i];

或者,如果您想将其全部保存在一个字符串中:

std::stringstream ss;
for(int i=0; i<data_length; ++i)
    ss << std::hex << (int)data[i];
std::string mystr = ss.str();
于 2014-03-20T09:44:41.737 回答
19

这里有一些东西:

char const hex_chars[16] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };

for( int i = data; i < data_length; ++i )
{
    char const byte = data[i];

    string += hex_chars[ ( byte & 0xF0 ) >> 4 ];
    string += hex_chars[ ( byte & 0x0F ) >> 0 ];
}
于 2012-05-23T15:44:21.017 回答
10

最简单的:

int main()
{
    const char* str = "hello";
    for (const char* p = str; *p; ++p)
    {
        printf("%02x", *p);
    }
    printf("\n");
    return 0;
}
于 2012-05-23T16:06:27.603 回答
8

我在这里找到了很好的例子Display-char-as-Hexadecimal-String-in-C++

  std::vector<char> randomBytes(n);
  file.read(&randomBytes[0], n);

  // Displaying bytes: method 1
  // --------------------------
  for (auto& el : randomBytes)
    std::cout << std::setfill('0') << std::setw(2) << std::hex << (0xff & (unsigned int)el);
  std::cout << '\n';

  // Displaying bytes: method 2
  // --------------------------
  for (auto& el : randomBytes)
    printf("%02hhx", el);
  std::cout << '\n';
  return 0;

如上所示的方法1可能是更C++的方式:

强制转换为无符号整数
用于std::hex将值表示为十六进制数字
使用std::setwstd::setfillfrom<iomanip>格式化
请注意,您需要屏蔽强制转换的 int0xff以显示最低有效字节:
(0xff & (unsigned int)el)

否则,如果设置了最高位,则强制转换将导致三个最高有效字节设置为ff

于 2019-09-10T14:48:14.830 回答
7

上面的代码片段在字符串中提供了不正确的字节顺序,所以我对其进行了一些修复。

char const hex[16] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A',   'B','C','D','E','F'};

std::string byte_2_str(char* bytes, int size) {
  std::string str;
  for (int i = 0; i < size; ++i) {
    const char ch = bytes[i];
    str.append(&hex[(ch  & 0xF0) >> 4], 1);
    str.append(&hex[ch & 0xF], 1);
  }
  return str;
}
于 2012-06-19T20:16:21.717 回答
3

使用提升:

#include <boost/algorithm/hex.hpp>

std::string s("tralalalala");
std::string result;
boost::algorithm::hex(s.begin(), s.end(), std::back_inserter(result));
于 2019-03-08T22:19:23.460 回答
0

您可以尝试使用此代码将字节从数据包转换为以空字符结尾的字符串并存储到“字符串”变量以进行处理。

const int buffer_size = 2048;
// variable for storing buffer as printable HEX string
char data[buffer_size*2];
// receive message from socket
int ret = recvfrom(sock, buffer, sizeofbuffer, 0, reinterpret_cast<SOCKADDR *>(&from), &size);
// bytes converting cycle
for (int i=0,j=0; i<ret; i++,j+=2){ 
    char res[2]; 
    itoa((buffer[i] & 0xFF), res, 16);
        if (res[1] == 0) {
            data[j] = 0x30; data[j+1] = res[0];
        }else {
            data[j] = res[0]; data[j + 1] = res[1];
        }
}
// Null-Terminating the string with converted buffer
data[(ret * 2)] = 0;

当我们发送带有十六进制字节 0x01020E0F 的消息时,变量“data”具有字符串“01020e0f”的 char 数组。

于 2017-07-19T10:58:52.570 回答
-3

你可以使用std::hex

例如。

std::cout << std::hex << packet;
于 2012-05-23T15:57:33.137 回答