std::stoi
STOL:STOL:Stoll
Defined in header | | |
---|---|---|
int stoi( const std::string& str, std::size_t* pos = 0, int base = 10 int stoi( const std::wstring& str, std::size_t* pos = 0, int base = 10 | (1) | (since C++11) |
long stol( const std::string& str, std::size_t* pos = 0, int base = 10 long stol( const std::wstring& str, std::size_t* pos = 0, int base = 10 | (2) | (since C++11) |
long long stoll( const std::string& str, std::size_t* pos = 0, int base = 10 long long stoll( const std::wstring& str, std::size_t* pos = 0, int base = 10 | (3) | (since C++11) |
解释字符串中的有符号整数值。str
...
1%29次电话std::strtol
(str.c_str(), &ptr, base)
或std::wcstol
(str.c_str(), &ptr, base)
2%29次电话std::strtol
(str.c_str(), &ptr, base)
或std::wcstol
(str.c_str(), &ptr, base)
3%29次电话std::strtoll
(str.c_str(), &ptr, base)
或std::wcstoll
(str.c_str(), &ptr, base)
丢弃通过调用所标识的任何空白字符%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
,则基为十六进制,否则基为十进制。
如果减号是输入序列的一部分,则从数字序列中计算的数值将被否定,就像一元减去在结果类型中。
如果pos
不是空指针,则是指针。ptr
-内部转换功能-将接收第一个未转换字符的地址str.c_str()
,则该字符的索引将被计算并存储在*pos
,给出通过转换处理的字符数。
参数
str | - | the string to convert |
---|---|---|
pos | - | address of an integer to store the number of characters processed |
base | - | the number base |
返回值
转换为指定有符号整数类型的字符串。
例外
std::invalid_argument
如果不能执行转换
std::out_of_range
如果转换后的值将超出结果类型的范围,或者如果基础函数%28 std::strtol或std::strtoll%29集errno
到ERANGE
...
例
二次
#include <iostream>
#include <string>
int main()
{
std::string str1 = "45";
std::string str2 = "3.14159";
std::string str3 = "31337 with words";
std::string str4 = "words and 2";
int myint1 = std::stoi(str1
int myint2 = std::stoi(str2
int myint3 = std::stoi(str3
// error: 'std::invalid_argument'
// int myint4 = std::stoi(str4
std::cout << "std::stoi(\"" << str1 << "\") is " << myint1 << '\n';
std::cout << "std::stoi(\"" << str2 << "\") is " << myint2 << '\n';
std::cout << "std::stoi(\"" << str3 << "\") is " << myint3 << '\n';
//std::cout << "std::stoi(\"" << str4 << "\") is " << myint4 << '\n';
}
二次
产出:
二次
std::stoi("45") is 45
std::stoi("3.14159") is 3
std::stoi("31337 with words") is 31337
二次
另见
atoiatolatoll | converts a byte string to an integer value (function) |
---|---|
stoulstoull (C++11)(C++11) | converts a string to an unsigned integer (function) |
stofstodstold (C++11)(C++11)(C++11) | converts a string to a floating point value (function) |
to_string (C++11) | converts an integral or floating point value to string (function) |
from_chars (C++17) | converts a character sequence to an integer or floating-point value (function) |
© cppreference.com
在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。