std::sub_match<BidirIt>:: swap
|
void
swap
(
sub_match
&
s
)
noexcept
(
/* siehe unten */
)
;
|
(seit C++11) | |
Tauscht den Inhalt zweier Teilübereinstimmungsobjekte. Entspricht
this
-
>
pair
<
BidirIt, BidirIt
>
::
swap
(
s
)
;
std::
swap
(
matched, s.
matched
)
;
Inhaltsverzeichnis |
Parameter
| s | - |
ein
sub_match
zum Austauschen
|
| Typanforderungen | ||
-
BidirIt
muss die Anforderungen von
LegacySwappable
erfüllen.
|
||
Exceptions
Beispiel
#include <cassert> #include <iostream> #include <regex> int main() { const char* s = "Quick red cat"; std::sub_match<const char*> x, y; x.first = &s[0]; x.second = &s[5]; x.matched = false; y.first = &s[012]; y.second = &s[13]; y.matched = true; std::cout << "Before swap:\n"; std::cout << "x.str() = [" << x.str() << "]\n"; std::cout << "y.str() = [" << y.str() << "]\n"; assert(!x.matched and y.matched); x.swap(y); std::cout << "After swap:\n"; std::cout << "x.str() = [" << x.str() << "]\n"; std::cout << "y.str() = [" << y.str() << "]\n"; assert(x.matched and !y.matched); }
Ausgabe:
Before swap: x.str() = [] y.str() = [cat] After swap: x.str() = [cat] y.str() = []
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 |
|---|---|---|---|
| LWG 3204 | C++11 |
std::sub_match
verwendete geerbte
std
::
pair
::
swap
(
pair
&
)
was zu einem Slicing führte |
std :: sub_match :: swap ( sub_match & ) wurde hinzugefügt |