#include <iostream> // std::cout
#include <string> // std::string, std::stoi
int main ()
{
const char* arrNumber = "ff000A;";
const std::string firstNum = std::string(arrNumber, 2);
const std::string secondNum = std::string(arrNumber+2, 4);
const int i_first = std::stoi(firstNum, nullptr, 16);
const int i_second= std::stoi(secondNum, nullptr, 16);
std::cout << "i_first: " << i_first << std::endl;
std::cout << "i_second: " << i_second << std::endl;
return 0;
}
我这里有两个问题。
如何将固定长度的
char*
转换为数字?在上面的例子中,我们需要将前两个十六进制字符提取为一个整数。由于构建了std::string
,所提出的方法很慢,我正在寻找类似于以下原型的更好的解决方案。stoi_x(const char* start_, size_t len, int base = 10)
给定这个原型,上面的例子可以写成如下:
const int i_first = stoi_x(arrNumber, 2, 16);
如何将没有空终止符的
char*
转换为数字?同样,我正在寻找类似于以下原型的更好解决方案。stoi_x(const char* start_, char end_, int base = 10)
给定这个原型,上面的例子可以写成如下:
const int i_second = stoi_x(arrNumber+2, ';', 16);
std::from_chars
,它将使您开箱即用。 它采用指向开始元素的指针和经过最后一个元素的指针,并将其转换为数字。 如果它根本无法转换字符串,它将填充返回对象中的错误代码,否则它会转换它可以转换的内容,并返回一个指针,指向它无法在返回对象中转换的数据部分。 在代码中使用它将其更改为
int main ()
{
const char* arrNumber = "ff000A;";
int i_first, i_second;
std::from_chars(arrNumber, arrNumber + 2, i_first, 16);
std::from_chars(arrNumber + 2, arrNumber + 6, i_second, 16);
std::cout << "i_first: " << i_first << std::endl;
std::cout << "i_second: " << i_second << std::endl;
return 0;
}
如果你不喜欢这样,你不能将转换的结果分配给一个常量变量,那么你可以把它包装在你自己的函数中,比如
template<typename T>
auto from_chars(char const * begin, char const * end, int base = 10)
{
T ret{};
std::from_chars(begin, end, ret, base);
return ret;
}
然后你可以像这样使用它
int main ()
{
const char* arrNumber = "ff000A;";
const int i_first = from_chars<int>(arrNumber, arrNumber + 2, 16);
const int i_second = from_chars<int>(arrNumber + 2, arrNumber + 6, 16);
std::cout << "i_first: " << i_first << std::endl;
std::cout << "i_second: " << i_second << std::endl;
return 0;
}
请注意,我没有进行任何错误处理。 在生产代码中,您应该检查是否发生了错误,因为std::from_chars
不会引发任何异常。