Namespaces
Variants

std:: begin, std:: cbegin

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
begin cbegin
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
헤더에 정의됨 <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 */ )

- > decltype ( std :: begin ( c ) ) ;
(4) (C++14부터)

주어진 범위의 시작 부분을 가리키는 반복자를 반환합니다.

1,2) c. begin ( ) 을 반환합니다. 이는 일반적으로 c 가 나타내는 시퀀스의 시작 부분을 가리키는 반복자입니다.
1) 만약 C 가 표준 Container 라면, C::iterator 객체를 반환합니다.
2) 만약 C 가 표준 Container 라면, C::const_iterator 객체를 반환합니다.
3) 배열의 시작 부분을 가리키는 포인터를 반환합니다.
4) 반환값 std :: begin ( c ) , c 는 항상 const-qualified로 처리됩니다.
만약 C 가 표준 Container 라면, C::const_iterator 객체를 반환합니다.

range-begin-end.svg

목차

매개변수

c - begin 멤버 함수를 가진 컨테이너 또는 뷰
array - 임의 타입의 배열

반환값

1,2) c. begin ( )
3) array
4) c. begin ( )

예외

4)
noexcept 명세:
noexcept ( noexcept ( std :: begin ( c ) ) )

오버로드

적합한 begin() 멤버 함수를 노출하지 않지만 반복 가능한 클래스 및 열거형에 대해 begin 의 사용자 정의 오버로드를 제공할 수 있습니다. 다음 오버로드들은 표준 라이브러리에서 이미 제공됩니다:

std::begin 오버로드 std::begin
(함수 템플릿)
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;
    }
}

인수 의존적 탐색 에 의해 발견된 begin 의 오버로드는 std::ranges::begin , std::ranges::cbegin std::ranges::begin 에 의존하는 다른 커스터마이제이션 포인터 객체들의 동작을 사용자 정의하는 데 사용될 수 있습니다.

(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)
컨테이너나 배열의 끝을 가리키는 반복자를 반환합니다
(함수 템플릿)
범위의 시작을 가리키는 반복자를 반환합니다
(커스터마이제이션 포인트 객체)
읽기 전용 범위의 시작을 가리키는 반복자를 반환합니다
(커스터마이제이션 포인트 객체)