std::experimental::ranges:: RandomAccessIterator
|
Défini dans l'en-tête
<experimental/ranges/iterator>
|
||
|
template
<
class
I
>
concept
bool
RandomAccessIterator
=
|
(ranges TS) | |
Le concept
RandomAccessIterator<I>
affine
BidirectionalIterator
en ajoutant la prise en charge de l'avancement en temps constant avec les opérateurs
+=
,
+
,
-=
, et
-
, le calcul de distance en temps constant avec
-
, et la notation de tableau avec l'indexation.
Soient
a
et
b
des itérateurs valides de type
I
tels que
b
soit accessible depuis
a
, et soit
n
une valeur de type
ranges
::
difference_type_t
<
I
>
égale à
b
-
a
.
RandomAccessIterator<I>
est satisfait seulement si :
- ( a + = n ) est égal à b .
- std:: addressof ( a + = n ) est égal à std:: addressof ( a ) .
- ( a + n ) est égal à ( a + = n ) .
- ( a + n ) est égal à ( n + a ) .
-
Pour deux entiers positifs quelconques
xety, si a + ( x + y ) est valide, alors a + ( x + y ) est égal à ( a + x ) + y . - a + 0 est égal à a .
- Si ( a + ( n - 1 ) ) est valide, alors -- b est égal à ( a + ( n - 1 ) ) .
- ( b + = - n ) et ( b - = n ) sont tous deux égaux à a .
- std:: addressof ( b - = n ) est égal à std:: addressof ( b ) .
- ( b - n ) est égal à ( b - = n ) .
- Si b est déréférençable, alors a [ n ] est valide et est égal à * b .
- bool ( a <= b ) est true .
Préservation de l'égalité
Une expression est préservatrice d'égalité si elle produit des résultats égaux pour des entrées égales.
- Les entrées d'une expression consistent en ses opérandes.
- Les sorties d'une expression consistent en son résultat et tous les opérandes modifiés par l'expression (le cas échéant).
Toute expression devant préserver l'égalité doit en outre être stable : deux évaluations d'une telle expression avec les mêmes objets d'entrée doivent produire des sorties égales en l'absence de toute modification explicite intervenant entre-temps sur ces objets d'entrée.
Sauf indication contraire, toute expression utilisée dans une requires-expression doit être égalité-préservante et stable, et l'évaluation de l'expression ne peut modifier que ses opérandes non constants. Les opérandes constants ne doivent pas être modifiés.
Variations d'expressions implicites
Une requires-expression qui utilise une expression non modifiante pour un opérande constant lvalue donné exige également implicitement des variations supplémentaires de cette expression qui acceptent un lvalue non constant ou un rvalue (éventuellement constant) pour l'opérande spécifié, sauf si une telle variation d'expression est explicitement exigée avec une sémantique différente. Ces variations d'expression implicites doivent satisfaire aux mêmes exigences sémantiques que l'expression déclarée. La mesure dans laquelle une implémentation valide la syntaxe des variations n'est pas spécifiée.