将从二进制文件读取的字符串转换为整数

converting a string read from binary file to integer

我有一个二进制文件。我使用 fstream 一次读取 16 个字节。

我想将其转换为整数。我试过atoi。但它没有用。 在 python 中,我们可以通过使用 stringobtained.encode('utf-8') 转换为字节流,然后使用 int(bytestring.hex(),16) 将其转换为 int 来实现。我们应该按照 python 中完成的这样一个详细的步骤还是有办法直接转换它?

ifstream file(binfile, ios::in | ios::binary | ios::ate);
if (file.is_open())
{

    size = file.tellg();
    memblock = new char[size];
    file.seekg(0, ios::beg);
    while (!file.eof())
    {
        file.read(memblock, 16);            
        int a = atoi(memblock); // doesnt work 0 always
        cout << a << "\n";
        memset(memblock, 0, sizeof(memblock));
    }
    file.close();

编辑:

这是文件的示例内容。

53 51 4C 69 74 65 20 66 6F 72 6D 61 74 20 33 00
04 00 01 01 00 40 20 20 00 00 05 A3 00 00 00 47
00 00 00 2E 00 00 00 3B 00 00 00 04 00 00 00 01

我需要将其读取为 16 字节,即一次读取 32 个十六进制数字。(即示例文件内容中的一行)并将其转换为整数。 所以当阅读 53 51 4C 69 74 65 20 66 6F 72 6D 61 74 20 33 00 时,我应该得到,110748049513798795666017677735771517696

但是我做不到。即使在尝试 strtoull 之后,我总是得到 0。我是不是读错了文件,或者我错过了什么。

你想要的是二进制数:

    short value ;
    file.read(&value, sizeof (value));            

根据文件的写入方式和您的处理器,您可能必须使用位操作反转值中的字节。

你这里有很多问题。首先是 C++ 没有标准的 128 位整数类型。您也许可以找到编译器扩展,例如 Is there a 128 bit integer in gcc? or Is there a 128 bit integer in C++?.

其次,您正在尝试解码原始字节而不是字符串。 atoi 将在它遇到的第一个非数字字符处停止,256 次中有 246 次将是第一个字节,因此它 returns 为零。如果你非常不幸,你将读取 16 个有效数字并且 atoi 将开始读取未初始化的内存,导致未定义的行为。

反正你不需要atoi,你的问题比那简单多了。您只需要将 assemble 16 个字节转换为一个整数,这可以通过移位和 or 运算符来完成。唯一的麻烦是 read 想要一个 char 类型,它可能会被签名,而你需要无符号字节。

ifstream file(binfile, ios::in | ios::binary);
char memblock[16];
while (file.read(memblock, 16))
{
    uint128_t a = 0;
    for (int i = 0; i < 16; ++i)
    {
        a = (a << 8) | (static_cast<unsigned int>(memblock[i]) & 0xff);
    }
    cout << a << "\n";
}
file.close();