std:: begin, std:: cbegin
|
헤더에 정의됨
<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부터 noexcept) (C++14부터 constexpr) |
|
template
<
class
C
>
constexpr
auto
cbegin
(
const
C
&
c
)
noexcept
(
/* see below */
)
|
(4) | (C++14부터) |
주어진 범위의 시작 부분을 가리키는 반복자를 반환합니다.
목차 |
매개변수
| c | - |
begin
멤버 함수를 가진 컨테이너 또는 뷰
|
| array | - | 임의 타입의 배열 |
반환값
예외
오버로드
적합한
begin()
멤버 함수를 노출하지 않지만 반복 가능한 클래스 및 열거형에 대해
begin
의 사용자 정의 오버로드를 제공할 수 있습니다. 다음 오버로드들은 표준 라이브러리에서 이미 제공됩니다:
|
std::begin 오버로드
std::begin
(함수 템플릿) |
|
|
(C++11)
|
std::begin 오버로드
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; } }
|
인수 의존적 탐색
에 의해 발견된
|
(C++20 이후) |
참고 사항
비-배열 오버로드들은
C::begin
의 동작을 정확히 반영합니다.
멤버 함수가 합리적인 구현을 가지고 있지 않을 경우 그 효과는 놀라울 수 있습니다.
std::cbegin
는 멤버 및 비멤버 범위 접근의 통합을 위해 도입되었습니다. 참고:
LWG issue 2128
.
만약
C
가 shallow-const 뷰인 경우,
std::cbegin
이 mutable iterator를 반환할 수 있습니다. 이러한 동작은 일부 사용자에게 예상치 못한 결과를 초래할 수 있습니다. 관련 내용은
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)
|
읽기 전용 범위의 시작을 가리키는 반복자를 반환합니다
(커스터마이제이션 포인트 객체) |