我遇到了一个问题,C++ 试图读取一个以十六进制形式填充有符号整数并将它们解析为向量的文本文件。我使用 C++ 流到变量重定向(流 >> var),并且似乎没有正确解析负数 - 变量获取值 0,并且设置了流失败标志。
如果我尝试使用 strtol() 函数转换字符串,结果与预期一致。同样,如果我尝试首先将流重定向到无符号整数,然后将变量转换为有符号整数,则结果再次正确并且不会报告流错误。
我在 Debian 9.1 (x64) 上使用 gcc 6.3.0,在 Xeon E5-2643 v3 系统上运行。
有没有其他人遇到过这个问题?我希望转换的工作方式与 strtol 函数相同,并且不会报告任何流错误。我是否缺少一些流设置/忘记调用某些函数或在这里设置一些标志?
任何建议将不胜感激。
下面附上一个演示此问题的示例 C++ 程序。
#include <iostream>
#include <sstream>
#include <cstdio>
#include <cstdlib>
#include <cstdint>
int main()
{
const char* minus_one = "0xffffffff";
std::stringstream ss;
ss << minus_one;
std::cout << "input string : " << ss.str() << "\n"; // outputs "0xffffffff"
// C-style conversion
int32_t cint;
cint = strtol(ss.str().c_str(), NULL, 0);
std::cout << "strtol conv : " << cint << " (" << std::hex << cint << ")\n"; // outputs "-1 (ffffffff)"
std::cout << std::dec;
// C++-style conversion
int32_t cppint;
ss >> std::hex >> cppint;
std::cout << std::dec << "ssextr conv : " << cppint << " (" << std::hex << cppint << ")\n"; // outputs "0 (0)" <- ERROR
std::cout << std::dec;
if (ss.fail()) std::cout << "Error converting number.\n";
// C++-style conversion with cast
uint32_t cppuint;
int32_t cppint2;
ss.clear();
ss.str(minus_one);
ss >> std::hex >> cppuint;
cppint2 = (int32_t)cppuint;
std::cout << std::dec << "ssextr cast conv: " << cppint2 << " (" << std::hex << cppint2 << ")\n"; // outputs "-1 (0xffffffff)"
std::cout << std::dec;
if (ss.fail()) std::cout << "Error converting number.\n";
exit(EXIT_SUCCESS);
}