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

converting a string read from binary file to integer

本文关键字:转换 整数 字符串 二进制文件 读取      更新时间:2023-10-16

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

我想将其转换为整数。我试了试阿托伊。但它没有用。在python中,我们可以通过使用stringyield.encode('utf-8')转换为字节流,然后使用int(bytestring.hex(),16将其转换为int来做到这一点。我们应该遵循在python中完成的elloborate步骤,还是有没有办法直接转换它?

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。我是否读错了文件,或者我错过了什么。

你在这里有很多问题。首先,C++没有标准的 128 位整数类型。您也许可以找到编译器扩展,例如请参阅 gcc 中有 128 位整数吗?或者C++中是否有 128 位整数?

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

反正你不需要atoi,你的问题比这简单得多。您只需要将 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();

它的数字是二进制的,你想要的是:

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

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