我正在尝试从字符串转换为uint64_t整数。stoi
返回一个 32 位整数,因此在我的情况下它不起作用。还有其他解决方案吗?
如果您使用的是 C++11 或更高版本,请尝试std::stoull
。
这篇文章也可能有所帮助。我没有将其标记为重复,因为另一个问题是关于 C 的。
试试这个:
#include <iostream>
#include <sstream>
#include <cstdint>
int main() {
uint64_t value;
std::istringstream iss("18446744073709551610");
iss >> value;
std::cout << value;
}
观看现场演示
这可能也适用于过时的标准。
如果您使用的是 C++11 或更高版本,则可以使用
请参阅以下示例
#include <iostream>
#include <string>
#include <cstdlib>
int main()
{
std::string value= "14443434343434343434";
uint64_t a;
char* end;
a= strtoull( value.c_str(), &end,10 );
std::cout << "UInt64: " << a << "n";
}
所有这些解决方案都不符合我的需求。
- istringstream- 将字符串"123asd"解析为123。
- 斯托尔- 会提出和错误,我不想 使用尝试捕获。
- 当时没有使用boost。
所以我只使用 for 循环:
uint64_t val = 0;
for (auto ch: new_str) {
if (not isdigit(ch)) return 0;
val = 10 * val + (ch - '0');
}
编辑: 另一个问题是溢出,如果字符串大于uint64_t。我添加了另一个开始 if 来检查字符串中字符的数量。
如果你正在使用 boost,你可以使用 boost::lexical_cast
#include <iostream>
#include <string>
#include <boost-1_61/boost/lexical_cast.hpp> //I've multiple versions of boost installed, so this path may be different for you
int main()
{
using boost::lexical_cast;
using namespace std;
const string s("2424242");
uint64_t num = lexical_cast<uint64_t>(s);
cout << num << endl;
return 0;
}
现场示例:http://coliru.stacked-crooked.com/a/c593cee68dba0d72
注意:这是针对 c 的解决方案,不适用于C++。所以在C++可能比这更难。 在这里,我们将字符串十六进制转换为uint64_t十六进制值。字符串的所有单个字符都转换为十六进制整数 ony。例如,在基数 10 -> 字符串 = "123":
- 第一个循环:值为 1
- 第二个循环:值为 1*10 + 2 = 12
- 第 3 个循环:值为 12*10 + 3 = 123
所以像这个逻辑用于将十六进制字符的字符串转换为uint_64hex值。
uint64_t stringToUint_64(String value) {
int stringLenght = value.length();
uint64_t uint64Value = 0x0;
for(int i = 0; i<=stringLenght-1; i++) {
char charValue = value.charAt(i);
uint64Value = 0x10 * uint64Value;
uint64Value += stringToHexInt(charValue);
}
return uint64Value;
}
int stringToHexInt(char value) {
switch(value) {
case '0':
return 0;
break;
case '1':
return 0x1;
break;
case '2':
return 0x2;
break;
case '3':
return 0x3;
break;
case '4':
return 0x4;
break;
case '5':
return 0x5;
break;
case '6':
return 0x6;
break;
case '7':
return 0x7;
break;
case '8':
return 0x8;
break;
case '9':
return 0x9;
break;
case 'A':
case 'a':
return 0xA;
break;
case 'B':
case 'b':
return 0xB;
break;
case 'C':
case 'c':
return 0xC;
break;
case 'D':
case 'd':
return 0xD;
break;
case 'E':
case 'e':
return 0xE;
break;
case 'F':
case 'f':
return 0xF;
break;
}
}