我想知道为什么在将十六进制字符串(0x1)转换为uint8时得到0的结果。
我尝试使用boost::lexical_cast
,但我收到bad_lexical_cast
例外。因此,我决定使用stringstream
,但我得到的值不正确。
...
uint8_t temp;
std::string address_extension = "0x1";
std::cout << "Before: " << address_extension << std::endl;
StringToNumeric(address_extension, temp);
std::cout << "After: " << temp << std::endl;
...
template <typename T>
void StringToNumeric(const std::string& source, T& target)
{
//Check if source is hex
if(IsHexNotation(source))
{
std::stringstream ss;
//Put value in the stream
ss << std::hex << source;
//Stream the hex value into a target type
ss >> target;
}
}
您可以放心IsHexNotation()
正常工作,并且不会更改声明的来源:
bool IsHexNotation(const std::string& source)
将十六进制字符串转换为uint8的正确方法是什么(假设十六进制字符串适合数据类型)?
答案 0 :(得分:5)
使用这样的代码对我有用:
std::stringstream ss;
int target(0);
ss << std::hex << source;
if (ss >> target) {
std::cout << "value=" << target << '\n';
}
else {
std::cout << "failed to read value\n";
}
但是,我记得有一个关于写入后字符串流的读取位置应该在哪里的讨论。由于它主要遵循文件流模型,因此即使它是相同的位置,您也需要寻找所需的位置。一些实现使用公共位置,而其他实现使用单独的读取和写入位置。您可以尝试使用
ss.seekg(0, std::ios_base::beg);
确保读取位置位于流的开头。或者,我认为最好是初始化std::istringstream
并直接从中读取:
std::istringstream in(source);
if (in >> std::hex >> target) { ... }
请注意,您始终要检查提取是否成功:这样您会得到一个实际出错的提示,而值0
可能只是变量的初始值。