operator==, !=, <, <=, >, >=, <=> (std::shared_ptr)
| Definiert in Header <memory> |
||
| Vergleicht zwei shared_ptr Objekte. |
||
| template< class T, class U > bool operator==( const std::shared_ptr<T>& lhs, |
(1) | (seit C++11) |
| template< class T, class U > bool operator!=( const std::shared_ptr<T>& lhs, |
(2) | (seit C++11) (bis C++20) |
| template< class T, class U > bool operator<( const std::shared_ptr<T>& lhs, |
(3) | (seit C++11) (bis C++20) |
| template< class T, class U > bool operator>( const std::shared_ptr<T>& lhs, |
(4) | (seit C++11) (bis C++20) |
| template< class T, class U > bool operator<=( const std::shared_ptr<T>& lhs, |
(5) | (seit C++11) (bis C++20) |
| template< class T, class U > bool operator>=( const std::shared_ptr<T>& lhs, |
(6) | (seit C++11) (bis C++20) |
| template< class T, class U > std::strong_ordering operator<=>( const std::shared_ptr<T>& lhs, |
(7) | (seit C++20) |
| Vergleicht einen shared_ptr mit einem Nullzeiger. |
||
| template< class T > bool operator==( const std::shared_ptr<T>& lhs, std::nullptr_t ) noexcept; |
(8) | (seit C++11) |
| template< class T > bool operator==( std::nullptr_t, const std::shared_ptr<T>& rhs ) noexcept; |
(9) | (seit C++11) (bis C++20) |
| template< class T > bool operator!=( const std::shared_ptr<T>& lhs, std::nullptr_t ) noexcept; |
(10) | (seit C++11) (bis C++20) |
| template< class T > bool operator!=( std::nullptr_t, const std::shared_ptr<T>& rhs ) noexcept; |
(11) | (seit C++11) (bis C++20) |
| template< class T > bool operator<( const std::shared_ptr<T>& lhs, std::nullptr_t ) noexcept; |
(12) | (seit C++11) (bis C++20) |
| template< class T > bool operator<( std::nullptr_t, const std::shared_ptr<T>& rhs ) noexcept; |
(13) | (seit C++11) (bis C++20) |
| template< class T > bool operator>( const std::shared_ptr<T>& lhs, std::nullptr_t ) noexcept; |
(14) | (seit C++11) (bis C++20) |
| template< class T > bool operator>( std::nullptr_t, const std::shared_ptr<T>& rhs ) noexcept; |
(15) | (seit C++11) (bis C++20) |
| template< class T > bool operator<=( const std::shared_ptr<T>& lhs, std::nullptr_t ) noexcept; |
(16) | (seit C++11) (bis C++20) |
| template< class T > bool operator<=( std::nullptr_t, const std::shared_ptr<T>& rhs ) noexcept; |
(17) | (seit C++11) (bis C++20) |
| template< class T > bool operator>=( const std::shared_ptr<T>& lhs, std::nullptr_t ) noexcept; |
(18) | (seit C++11) (bis C++20) |
| template< class T > bool operator>=( std::nullptr_t, const std::shared_ptr<T>& rhs ) noexcept; |
(19) | (seit C++11) (bis C++20) |
| template< class T > std::strong_ordering operator<=>( const std::shared_ptr<T>& lhs, |
(20) | (seit C++20) |
Vergleicht zwei shared_ptr<T> Objekte oder vergleicht shared_ptr<T> mit einem Nullzeiger.
Beachten Sie, dass die Vergleichsoperatoren für shared_ptr einfach Zeigerwerte vergleichen; die tatsächlich verwalteten Objekte werden *nicht* verglichen. Die Definition von operator< für shared_ptr ermöglicht die Verwendung von shared_ptrs als Schlüssel in assoziativen Containern wie std::map und std::set.
|
Die Operatoren |
(seit C++20) |
Inhalt |
[edit] Parameter
| lhs | - | Der linke shared_ptr zum Vergleichen |
| rhs | - | Der rechte shared_ptr zum Vergleichen |
[edit] Rückgabewert
[edit] Hinweise
In allen Fällen wird der gespeicherte Zeiger (derjenige, der von get() zurückgegeben wird) verglichen, nicht der verwaltete Zeiger (derjenige, der an den Deleter übergeben wird, wenn use_count Null erreicht). Die beiden Zeiger können sich bei einem shared_ptr unterscheiden, der mit dem Aliasing-Konstruktor erstellt wurde.
[edit] Beispiel
#include <iostream> #include <memory> int main() { std::shared_ptr<int> p1(new int(42)); std::shared_ptr<int> p2(new int(42)); std::cout << std::boolalpha << "(p1 == p1) : " << (p1 == p1) << '\n' << "(p1 <=> p1) == 0 : " << ((p1 <=> p1) == 0) << '\n' // Since C++20 // p1 and p2 point to different memory locations, so p1 != p2 << "(p1 == p2) : " << (p1 == p2) << '\n' << "(p1 < p2) : " << (p1 < p2) << '\n' << "(p1 <=> p2) < 0 : " << ((p1 <=> p2) < 0) << '\n' // Since C++20 << "(p1 <=> p2) == 0 : " << ((p1 <=> p2) == 0) << '\n'; // Since C++20 }
Mögliche Ausgabe
(p1 == p1) : true (p1 <=> p1) == 0 : true (p1 == p2) : false (p1 < p2) : true (p1 <=> p2) < 0 : true (p1 <=> p2) == 0 : false
[edit] 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 3427 | C++20 | operator<=>(shared_ptr, nullptr_t) war ill-formed |
Definition behoben |
[edit] Siehe auch
| gibt den gespeicherten Zeiger zurück (public member function) |