std::ranges:: begin
|
Definiert in Header
<ranges>
|
||
|
Definiert in Header
<iterator>
|
||
|
inline
namespace
/* unspecified */
{
inline
constexpr
/* unspecified */
begin
=
/* unspecified */
;
|
(seit C++20)
(Customization Point Object) |
|
|
Aufrufsignatur
|
||
|
template
<
class
T
>
requires
/* siehe unten */
|
(seit C++20) | |
Gibt einen Iterator zum ersten Element des Arguments zurück.
Wenn das Argument ein Lvalue ist oder
ranges::
enable_borrowed_range
<
std::
remove_cv_t
<
T
>>
true
ist, dann ist ein Aufruf von
ranges::begin
ausdrucksäquivalent
zu:
-
t
+
0
falls
t
einen Array-Typ hat.
-
Falls
std::
remove_all_extents_t
<
std::
remove_reference_t
<
T
>>
unvollständig ist, dann ist der Aufruf von
ranges::beginill-formed, keine Diagnose erforderlich.
-
Falls
std::
remove_all_extents_t
<
std::
remove_reference_t
<
T
>>
unvollständig ist, dann ist der Aufruf von
- Andernfalls, decay-copy ( t. begin ( ) ) (bis C++23) auto ( t. begin ( ) ) (seit C++23) , falls dieser Ausdruck gültig ist und sein Typ std::input_or_output_iterator modelliert.
-
Andernfalls,
decay-copy
(
begin
(
t
)
)
(bis C++23)
auto
(
begin
(
t
)
)
(seit C++23)
, falls
Tein Klassen- oder Enumerationstyp ist, dieser Ausdruck gültig ist und sein Typ std::input_or_output_iterator modelliert, wobei die Bedeutung vonbeginso festgelegt wird, als würde nur argument-dependent lookup durchgeführt.
In allen anderen Fällen ist ein Aufruf von
ranges::begin
fehlerhaft, was zu einem
Substitutionsfehler
führen kann, wenn der Aufruf im unmittelbaren Kontext einer Template-Instanziierung erscheint.
Inhaltsverzeichnis |
Customization Point Objects
Der Name
ranges::begin
bezeichnet ein
Customization Point Object
, welches ein konstantes
Funktionsobjekt
eines
Literal
semiregular
Klassentyps ist. Weitere Details finden Sie unter
CustomizationPointObject
.
Hinweise
Wenn das Argument ein R-Wert ist (d.h.
T
ist ein Objekttyp) und
ranges::
enable_borrowed_range
<
std::
remove_cv_t
<
T
>>
false
ist, ist der Aufruf von
ranges::begin
ungültig, was ebenfalls zu einem Substitutionsfehler führt.
Der Rückgabetyp modelliert std::input_or_output_iterator in allen Fällen.
Der C++20-Standard verlangt, dass, wenn der zugrundeliegende
begin
-Funktionsaufruf einen Prvalue zurückgibt, der Rückgabewert aus dem materialisierten temporären Objekt move-konstruiert wird. Alle Implementierungen geben stattdessen direkt den Prvalue zurück. Die Anforderung wird durch den nach-C++20-Vorschlag
P0849R8
korrigiert, um mit den Implementierungen übereinzustimmen.
Beispiel
#include <cassert> #include <ranges> #include <vector> int main() { std::vector v{3, 1, 4}; auto vi = std::ranges::begin(v); auto vci = std::ranges::cbegin(v); assert(*vi == 3 and *vi == *vci); ++vi; ++vci; // OK: vci ist ein modifizierbares Objekt *vi = 42; // OK: vi zeigt auf veränderbares Element // *vci = 13; // Fehler: vci zeigt auf unveränderliches Element int a[]{-5, 10, 15}; auto ai = std::ranges::begin(a); // funktioniert auch mit C-Arrays assert(*ai == -5); *ai = 42; // OK }
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| P2602R2 | C++20 |
Es existiert ein Mechanismus, um bestimmte non-member
begin
zu verbieten, die durch
ADL
gefunden werden
|
Dieser Mechanismus wurde entfernt |
Siehe auch
|
(C++20)
|
gibt einen Iterator zum Anfang eines schreibgeschützten Bereichs zurück
(Anpassungspunktobjekt) |
|
(C++11)
(C++14)
|
gibt einen Iterator zum Anfang eines Containers oder Arrays zurück
(Funktionstemplate) |