std::begin, std::cbegin
來自 cppreference.com
< cpp | 迭代器 (iterator)
定義於標頭檔案 <array> |
||
在標頭檔案 <deque> 中定義 |
||
在標頭檔案 <flat_map> 中定義 |
||
在標頭檔案 <flat_set> 中定義 |
||
在標頭檔案 <forward_list> 中定義 |
||
在標頭檔案 <inplace_vector> 中定義 |
||
定義於標頭檔案 <iterator> |
||
定義於標頭檔案 <list> |
||
定義於標頭檔案 <map> |
||
在標頭檔案 <regex> 中定義 |
||
在標頭檔案 <set> 中定義 |
||
在標頭檔案 <span> 中定義 |
||
定義於標頭檔案 <string> |
||
定義於標頭檔案 <string_view> |
||
在標頭檔案 <unordered_map> 中定義 |
||
定義於標頭檔案 <unordered_set> |
||
在標頭檔案 <vector> 中定義 |
||
template< class C > auto begin( C& c ) -> decltype(c.begin()); |
(1) | (C++11 起) (自 C++17 起為 constexpr) |
template< class C > auto begin( const C& c ) -> decltype(c.begin()); |
(2) | (C++11 起) (自 C++17 起為 constexpr) |
template< class T, std::size_t N > T* begin( T (&array)[N] ); |
(3) | (C++11 起) (C++14 起無異常) (C++14 起為 constexpr) |
template< class C > constexpr auto cbegin( const C& c noexcept(/* 見下文 */) |
(4) | (C++14 起) |
返回給定範圍的起始迭代器。
1,2) 返回 c.begin(),它通常是表示 c 的序列的起始迭代器。
3) 返回 array 的起始指標。
4) 返回 std::begin(c),其中 c 始終被視為 const 限定。
目錄 |
[編輯] 引數
c | - | 帶有 begin 成員函式的容器或檢視 |
array | - | 任意型別的陣列 |
[編輯] 返回值
1,2) c.begin()
3) array
4) c.begin()
[編輯] 異常
4)
noexcept 規範:
noexcept(noexcept(std::begin(c)))
[編輯] 過載
對於不暴露合適的 begin()
成員函式但可迭代的類和列舉,可以提供 begin
的自定義過載。標準庫已經提供了以下過載
過載 std::begin (函式模板) | |
(C++11) |
過載 std::begin (函式模板) |
支援基於範圍的 for 迴圈 (函式) | |
支援基於範圍的 for 迴圈 (函式) |
與 swap
的用法類似(在可交換 (Swappable) 中描述),在泛型上下文中 begin
函式的典型用法等價於 using std::begin; begin(arg);,這允許使用者定義型別的ADL選擇的過載和標準庫函式模板出現在同一個過載集中。
template<typename Container, typename Function> void for_each(Container&& cont, Function f) { using std::begin; auto it = begin(cont); using std::end; auto end_it = end(cont); while (it != end_it) { f(*it); ++it; } }
透過實參依賴查詢 (argument-dependent lookup) 找到的 |
(C++20 起) |
[編輯] 註解
非陣列過載精確地反映了 C::begin
的行為。如果成員函式沒有合理的實現,它們的效果可能會令人驚訝。
引入 std::cbegin
是為了統一成員和非成員範圍訪問。另見 LWG issue 2128。
如果 C
是淺 const 檢視,std::cbegin
可能會返回一個可變迭代器。這種行為對某些使用者來說是意想不到的。另見 P2276 和 P2278。
[編輯] 示例
執行此程式碼
#include <iostream> #include <iterator> #include <vector> int main() { std::vector<int> v = {3, 1, 4}; auto vi = std::begin(v); std::cout << std::showpos << *vi << '\n'; int a[] = {-5, 10, 15}; auto ai = std::begin(a); std::cout << *ai << '\n'; }
輸出
+3 -5
[編輯] 參閱
(C++11)(C++14) |
返回指向容器或陣列末尾的迭代器 (函式模板) |
(C++20) |
返回指向範圍開頭的迭代器 (定製點物件) |
(C++20) |
返回只讀範圍的起始迭代器 (定製點物件) |