public member function
<locale>

std::time_get::get_year

iter_type get_year (iter_type s, iter_type end, ios_base& str,                    ios_base::iostate& err, tm* t) const;
讀取年份
解析 send 之間的字元序列,並將其解釋為年份,將其值儲存在 t 指向的 tm 物件中。

該函式讀取字元,直到讀取的字元不能成為有效年份表示式的一部分,或者到達 end。序列中的下一個字元由函式返回的迭代器指向。

如果成功,該函式將設定 tm 結構體 t 的相關成員。其餘成員將保持不變。

在內部,此函式僅呼叫虛保護成員 do_get_year,該成員預設解析表示年份的字元序列。關於是否接受兩位數年份以及(如果接受)它們屬於哪個世紀,此函式未指定。

必要時,該函式會更新 err 以反映操作結果。
- 如果序列格式無效,函式將設定 failbit
- 否則,此行為未指定,儘管某些實現會為函式耗盡字元序列(即到達 end,無論成功還是失敗)的情況將 err 設定為 eofbit,否則設定為 goodbit
必要時,該函式會更新 err 以反映操作結果。
- 如果序列格式無效,函式將設定 failbit
- 如果函式在其操作過程中耗盡了字元序列(即到達 end),它會設定 eofbit(單個操作可能同時設定 failbiteofbit)。
- 否則,行為是未定義的,儘管某些實現會將 err 設定為 goodbit

引數

s, end
指向序列開始和結束字元的迭代器。使用的範圍是 [s,end),它包含 send 之間的所有字元,包括 s 指向的字元,但不包括 end 指向的字元。
成員型別 iter_type 是此 facet 的迭代器型別(定義為 time_get 的第二個模板引數 InputIterator 的別名)。預設情況下,這是 istreambuf_iterator,允許從 basic_istream 物件隱式轉換。
str
派生自 ios_base 的類物件(通常是輸入流物件)。它僅用於獲取格式資訊。
err
流錯誤狀態物件,型別為 ios_base::iostate,用於儲存錯誤狀態。
t
指向 struct tm (在標頭檔案 <ctime> 中定義)的指標,其成員在成功呼叫此成員函式後會被設定。

返回值

在操作之後,序列中緊隨最後一個被使用字元的下一個字元。
成員型別 iter_type 是此 facet 的迭代器型別(定義為 time_get 的第二個模板引數 InputIterator 的別名)。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// time_get::get_year example
#include <iostream>       // std::cout, std::ios
#include <sstream>        // std::istringstream
#include <ctime>          // std::tm
#include <locale>         // std::locale, std::time_get, std::use_facet

int main ()
{
  std::locale loc;        // classic "C" locale

  // get time_get facet:
  const std::time_get<char>& tmget = std::use_facet <std::time_get<char> > (loc);

  std::ios::iostate state;
  std::istringstream iss ("2013");
  std::tm when;

  tmget.get_year (iss, std::time_get<char>::iter_type(), iss, state, &when);

  std::cout << "year: " << when.tm_year << '\n';
  return 0;
}

可能的輸出

tm_year: 113

請注意,tm_year 中的 113 被解釋為 2013 年(有關更多資訊,請參閱 struct tm)。

資料競爭

訪問該物件以及 send 之間的整個範圍。
引數 strerrt 可能會被修改。

異常安全

如果丟擲異常,則“facet 物件”不會發生更改,儘管某些引數可能已被修改。

另見