函式模板
<string>

std::stoll

long long stoll (const string&  str, size_t* idx = 0, int base = 10);long long stoll (const wstring& str, size_t* idx = 0, int base = 10);
將字串轉換為長長整型
該函式解析str,將其內容解釋為指定base的整型數字,並將其作為以下型別的值返回:long long.

的值返回。如果idx不是空指標,函式還會將idx的值設定為str中數字之後第一個字元的位置。

此函式使用 strtoll(或 wcstoll)執行轉換(有關轉換過程的更多詳細資訊,請參閱 strtol)。

引數

str
具有整型數字表示的字串物件。
idx
指向型別為 size_t 的物件的指標,其值由函式設定為str中數值之後下一個字元的位置。
該引數也可以是一個空指標,此時它將不被使用。
base
決定有效字元及其解釋的數字基數(radix)。
如果是0,則使用的基數由序列中的格式確定(有關詳細資訊,請參閱strtol)。請注意,預設情況下此引數為10,而不是0.

返回值

成功時,函式將轉換後的整型數字作為以下型別的值返回:long long.

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// stoll example
#include <iostream>   // std::cout
#include <string>     // std::string, std::stoll

int main ()
{
  std::string str = "8246821 0xffff 020";

  std::string::size_type sz = 0;   // alias of size_t

  while (!str.empty()) {
    long long ll = std::stoll (str,&sz,0);
    std::cout << str.substr(0,sz) << " interpreted as " << ll << '\n';
    str = str.substr(sz);
  }

  return 0;
}

輸出
8246821 interpreted as 8246821
 0xffff interpreted as 65535
 020 interpreted as 16


複雜度

未定義,但通常與解釋的字元數呈線性關係。

資料競爭

修改idx指向的值 (如果idx不為零)。

異常

如果無法執行任何轉換,則丟擲invalid_argument異常。

)。如果讀取的值超出了long long,則丟擲out_of_range異常。

無效的idx會導致未定義行為

另見