std::ranges:: bidirectional_range
From cppreference.net
C++
Ranges library
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | ||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
|
Definiert im Header
<ranges>
|
||
|
template
<
class
T
>
concept bidirectional_range
=
|
(seit C++20) | |
Das
bidirectional_range
Konzept ist eine Verfeinerung des
range
Konzepts, für das
ranges::begin
einen Typ zurückgibt, der
bidirectional_iterator
modelliert.
Beispiel
Diesen Code ausführen
#include <forward_list> #include <list> #include <ranges> #include <set> #include <unordered_set> int main() { static_assert( std::ranges::bidirectional_range<std::set<int>> and not std::ranges::bidirectional_range<std::unordered_set<int>> and std::ranges::bidirectional_range<std::list<int>> and not std::ranges::bidirectional_range<std::forward_list<int>> ); }
Siehe auch
|
(C++20)
|
spezifiziert einen Bereich, dessen Iteratortyp
forward_iterator
erfüllt
(Konzept) |
|
(C++20)
|
spezifiziert einen Bereich, dessen Iteratortyp
random_access_iterator
erfüllt
(Konzept) |