std::wcstoll
STD::wcstol,std::wcstrol
Defined in header | | |
---|---|---|
long wcstol( const wchar_t* str, wchar_t** str_end, int base | | |
long long wcstoll( const wchar_t* str, wchar_t** 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 wide string to be interpreted |
---|---|---|
str_end | - | pointer to a pointer to wide character |
base | - | base of the interpreted integer value |
返回值
的内容对应的整数值。str
关于成功。如果转换值超出相应的返回类型范围,则会发生范围错误LONG_MAX
,,,LONG_MIN
,,,LLONG_MAX
或LLONG_MIN
会被归还。如果不能执行转换,0
会被归还。
例
二次
#include <iostream>
#include <string>
#include <errno.h>
#include <cwchar>
int main()
{
const wchar_t* p = L"10 200000000000000000000000000000 30 -40";
wchar_t *end;
std::wcout << "Parsing L'" << p << "':\n";
for (long i = std::wcstol(p, &end, 10
p != end;
i = std::wcstol(p, &end, 10))
{
std::wcout << "'" << std::wstring(p, end-p) << "' -> ";
p = end;
if (errno == ERANGE){
std::wcout << "range error, got ";
errno = 0;
}
std::wcout << i << '\n';
}
}
二次
可能的产出:
二次
Parsing L'10 200000000000000000000000000000 30 -40':
'10' -> 10
' 200000000000000000000000000000' -> range error, got 9223372036854775807
' 30' -> 30
' -40' -> -40
二次
另见
strtolstrtoll | converts a byte string to an integer value (function) |
---|---|
wcstoulwcstoull | converts a wide string to an unsigned integer value (function) |
wcstol,wcstrol文件
© cppreference.com
在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。