std::strtoul, std::strtoull
来自 cppreference.cn
定义于头文件 <cstdlib> |
||
unsigned long strtoul ( const char* str, char** str_end, int base ); |
(1) | |
unsigned long long strtoull( const char* str, char** str_end, int base ); |
(2) | (since C++11) |
解释一个无符号整数值,该值位于由 str 指向的字节字符串中。
丢弃任何空白字符(如调用 std::isspace 所识别),直到找到第一个非空白字符。然后尽可能多地获取字符,以形成有效的 base-n(其中 n=base
)无符号整数数字表示,并将它们转换为整数值。有效的无符号整数值由以下部分组成:
- (可选) 加号或减号
- (可选) 前缀 (
0
),指示八进制基数(仅当基数为 8 或 0 时适用) - (可选) 前缀 (
0x
或0X
),指示十六进制基数(仅当基数为 16 或 0 时适用) - 数字序列
字符的大小写被忽略。
当前安装的 C locale 可能接受其他数值格式。
如果 base
的值为 0,则数值基数会被自动检测:如果前缀是 0
,则基数为八进制;如果前缀是 0x
或 0X
,则基数为十六进制;否则基数为十进制。
如果减号是输入序列的一部分,则从数字序列计算出的数值会被取反,如同结果类型中的 一元减号 一样,这会应用无符号整数环绕规则。
这些函数会将由 str_end 指向的指针设置为指向已解释的最后一个字符之后的字符。如果 str_end 是空指针,则会被忽略。
目录 |
[编辑] 参数
str | - | 指向要解释的空字符结尾字节字符串的指针 |
str_end | - | 指向字符指针的指针,可能会被设置为指向已解释的最后一个字符之后的位置 |
base | - | 已解释整数值的基数 |
[编辑] 返回值
成功时,返回对应于 str 内容的整数值。如果转换后的值超出相应返回类型的范围,则会发生范围错误(errno 被设置为 ERANGE
),并返回 ULONG_MAX 或 ULLONG_MAX。如果无法执行转换,则返回 0。
[编辑] 示例
运行此代码
#include <cstdlib> #include <errno.h> #include <iostream> #include <string> int main() { const char* p = "10 200000000000000000000000000000 30 -40 - 42"; char* end = nullptr; std::cout << "Parsing '" << p << "':\n"; for (unsigned long i = std::strtoul(p, &end, 10); p != end; i = std::strtoul(p, &end, 10)) { std::cout << "'" << std::string(p, end - p) << "' -> "; p = end; if (errno == ERANGE) { errno = 0; std::cout << "range error, got "; } std::cout << i << '\n'; } std::cout << "After the loop p points to '" << p << "'\n"; }
可能的输出
Parsing '10 200000000000000000000000000000 30 -40 - 42': '10' -> 10 ' 200000000000000000000000000000' -> range error, got 18446744073709551615 ' 30' -> 30 ' -40' -> 18446744073709551576 After the loop p points to ' - 42'
[编辑] 参见
(C++11)(C++11) |
将字符串转换为无符号整数 (函数) |
(C++11) |
将字节字符串转换为整数值 (函数) |
(C++11)(C++11) |
将字节字符串转换为 std::intmax_t 或 std::uintmax_t (函数) |
将宽字符串转换为无符号整数值 (函数) | |
将字节字符串转换为浮点数值 (函数) | |
(C++17) |
将字符序列转换为整数或浮点数值 (函数) |
(C++11) |
将字节字符串转换为整数值 (函数) |
C 文档 关于 strtoul, strtoull
|