ifstream :: read不断返回错误的值

时间:2018-03-02 13:56:28

标签: c++ ifstream

我正在尝试读取.bin文件并返回十六进制值。一切正常,直到它必须读取像“F0”或“A0”这样的值。它不断返回“fffff0”或“ffffa0”。当我修改函数以返回十进制值时,控制台显示“-16”和“-96”,而所有其他正确的返回值都是正数。

void reader(string input) { 
int size;
char *storage;

ifstream file(input, ios::in | ios::binary);
if (file.is_open()) {
    file.seekg(0, ios::end);
    size = file.tellg();
    storage = new char[size];
    file.seekg(0, ios::beg);
    file.read(storage, size);
    file.close();
    for (int i = 0; i < size; i++) 
    {
        cout << hex << (int)storage[i] << endl;
    }
}
else {cout << "could not open file" << endl;}
}

1 个答案:

答案 0 :(得分:0)

“char”是签名值。当char的顶部位置位时,它表示负值(例如0x80到0xFF)。将负值转换为不同大小的整数时,将保留该值,从而产生不同的十六进制值。

#include <iostream>

int main()
{
    char ch = 0xF0;
    int value = ch;
    std::cout << value << std::endl;
    std::cout << std::hex << value << std::endl;
}

上述程序打印“-16,fffffff0”。该计划实际上相当于:

#include <iostream>

int main()
{
    char ch = -16;
    int value = ch;
    std::cout << value << std::endl;
    std::cout << std::hex << value << std::endl;
}

要获得预期的行为,您需要屏蔽值:

#include <iostream>

int main()
{
    char ch = 0xF0;
    int value = ch & 0xFF;
    std::cout << value << std::endl;
    std::cout << std::hex << value << std::endl;
}