std::strtoul
std::strtoul,std::strtoull
Defined in header | | |
---|---|---|
unsigned long strtoul( const char *str, char **str_end, int base | | |
unsigned long long strtoull( const char *str, char **str_end, int base | | (since C++11) |
指向的字节字符串中的无符号整数值。str
...
丢弃通过调用所标识的任何空白字符%28isspace()
%29直到找到第一个非空白字符,然后尽可能多地接受字符以形成有效的字符。基-n
%28其中n=基%29无符号整数表示并将它们转换为整数值。有效的无符号整数值由以下部分组成:
- %28可选%29加或减符号
- %2
8
可选%29前缀%28
0
%29表示八进制基%28
仅在基为8
或0
%29
- %28可选%29前缀%28
0x
或0X
%29表示十六进制基%28仅在基为16
或0
%29
- 数字序列
基的有效值集为{0,2,3,…,36}。基-2整数的有效数字集是{0,1
},对于基-3整数是{0,1,2
}等等。对于大于10
,有效数字包括字母字符,从Aa
对于基数-11整数,到Zz
基-36整数。字符的情况被忽略。
当前安装的C可以接受其他数字格式locale
...
如果基值为0
,则自动检测数字基:如果前缀为0
,则基为八进制,如果前缀为0x
或0X
,则基为十六进制,否则基为十进制。
如果减号是输入序列的一部分,则从数字序列中计算的数值将被否定,就像一元减去在结果类型中,该类型应用无符号整数环绕规则。
函数设置指向的指针。str_end
指向过去解释的最后一个字符的字符。如果str_end
是NULL
它被忽略了。
参数
str | - | pointer to the null-terminated byte string to be interpreted |
---|---|---|
str_end | - | pointer to a pointer to character. |
base | - | base of the interpreted integer value |
返回值
的内容对应的整数值。str
关于成功。如果转换值超出相应的返回类型范围,则会发生范围错误ULONG_MAX
或ULLONG_MAX
会被归还。如果不能执行转换,0
会被归还。
例
二次
#include <iostream>
#include <string>
#include <errno.h>
#include <cstdlib>
int main()
{
const char* p = "10 200000000000000000000000000000 30 -40";
char *end;
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){
std::cout << "range error, got ";
errno = 0;
}
std::cout << i << '\n';
}
}
二次
可能的产出:
二次
Parsing '10 200000000000000000000000000000 30 -40':
'10' -> 10
' 200000000000000000000000000000' -> range error, got 18446744073709551615
' 30' -> 30
' -40' -> 18446744073709551576
二次
另见
wcstoulwcstoull | converts a wide string to an unsigned integer value (function) |
---|---|
atoiatolatoll | converts a byte string to an integer value (function) |
strtolstrtoll | converts a byte string to an integer value (function) |
c strtoul,strtoull的文档
© cppreference.com
在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。