Namespaces
Variants

std::experimental::ranges:: Boolean

From cppreference.net
(Anmerkung: Da in diesem HTML-Abschnitt keinerlei Textinhalte vorhanden sind, die übersetzt werden müssten, bleibt die Ausgabe identisch mit der Eingabe. Die leeren td-Elemente enthalten keine übersetzbaren Texte.)
template < class B >

concept bool Boolean =
Movable < std:: decay_t < B >> &&
requires ( const std:: remove_reference_t < B > & b1,
const std:: remove_reference_t < B > & b2, const bool a ) {
{ b1 } - > ConvertibleTo < bool > && ;
{ ! b1 } - > ConvertibleTo < bool > && ;
{ b1 && a } - > Same < bool > && ;
{ b1 || a } - > Same < bool > && ;
{ b1 && b2 } - > Same < bool > && ;
{ a && b2 } - > Same < bool > && ;
{ b1 || b2 } - > Same < bool > && ;
{ a || b2 } - > Same < bool > && ;
{ b1 == b2 } - > ConvertibleTo < bool > && ;
{ b1 == a } - > ConvertibleTo < bool > && ;
{ a == b2 } - > ConvertibleTo < bool > && ;
{ b1 ! = b2 } - > ConvertibleTo < bool > && ;
{ b1 ! = a } - > ConvertibleTo < bool > && ;
{ a ! = b2 } - > ConvertibleTo < bool > && ;

} ;
(ranges TS)

Das Konzept Boolean<B> spezifiziert die Anforderungen für einen Typ, der in booleschen Kontexten verwendet werden kann. Damit Boolean erfüllt wird, müssen die logischen Operatoren das übliche Verhalten aufweisen (einschließlich Kurzschlussauswertung). Genauer gesagt, gegeben

Boolean<B> ist nur erfüllt, wenn:

  • bool ( b1 ) == ! bool ( ! b1 ) ;
  • b1 && b2 , b1 && bool ( b2 ) und bool ( b1 ) && b2 sind alle gleich bool ( b1 ) && bool ( b2 ) und haben dieselbe Kurzschlussauswertung;
  • b1 || b2 , b1 || bool ( b2 ) und bool ( b1 ) || b2 sind alle gleich bool ( b1 ) || bool ( b2 ) und haben dieselbe Kurzschlussauswertung;
  • bool ( b1 == b2 ) , bool ( b1 == bool ( b2 ) ) und bool ( bool ( b1 ) == b2 ) sind alle gleich ( bool ( b1 ) == bool ( b2 ) ) ;
  • bool ( b1 ! = b2 ) , bool ( b1 ! = bool ( b2 ) ) und bool ( bool ( b1 ) ! = b2 ) sind alle gleich ( bool ( b1 ) ! = bool ( b2 ) ) .

Gleichheitserhaltung

Ein Ausdruck ist gleichheitserhaltend , wenn er bei gleichen Eingaben gleiche Ausgaben liefert.

  • Die Eingaben eines Ausdrucks bestehen aus seinen Operanden.
  • Die Ausgaben eines Ausdrucks bestehen aus seinem Ergebnis und allen durch den Ausdruck modifizierten Operanden (falls vorhanden).

Jeder Ausdruck, der gleichungserhaltend sein muss, muss darüber hinaus stabil sein: Zwei Auswertungen eines solchen Ausdrucks mit denselben Eingabeobjekten müssen gleiche Ausgaben liefern, sofern keine explizite Änderung dieser Eingabeobjekte zwischen den Auswertungen erfolgt.

Sofern nicht anders angegeben, muss jeder Ausdruck, der in einem requires-expression verwendet wird, gleichheitserhaltend und stabil sein, und die Auswertung des Ausdrucks darf nur seine nicht-konstanten Operanden modifizieren. Operanden, die konstant sind, dürfen nicht modifiziert werden.

Implizite Ausdrucksvarianten

Ein requires-expression , der einen Ausdruck verwendet, der für einen konstanten Lvalue-Operanden nicht-modifizierend ist, erfordert implizit auch zusätzliche Variationen dieses Ausdrucks, die einen nicht-konstanten Lvalue oder (möglicherweise konstanten) Rvalue für den gegebenen Operanden akzeptieren, sofern nicht eine solche Ausdrucksvariation explizit mit abweichender Semantik gefordert wird. Diese impliziten Ausdrucksvariationen müssen dieselben semantischen Anforderungen erfüllen wie der deklarierte Ausdruck. Das Ausmaß, in dem eine Implementierung die Syntax der Variationen überprüft, ist nicht spezifiziert.

Hinweise

Beispiele für Boolean -Typen sind bool , std:: true_type und std:: bitset < N > :: reference . Zeiger sind keine Boolean -Typen.

Eine Ableitungsbedingung der Form { expression } - > Same < T > && erfordert effektiv, dass decltype ( ( expression ) ) && exakt derselbe Typ wie T&& ist. Dies beschränkt sowohl den Typ des Ausdrucks als auch seine Wertkategorie.