Namespaces
Variants

operator==, !=, <, <=, >, >=, <=> (std::shared_ptr)

From cppreference.net
Memory management library
( exposition only* )
Allocators
Uninitialized memory algorithms
Constrained uninitialized memory algorithms
Memory resources
Uninitialized storage (until C++20)
( until C++20* )
( until C++20* )
( until C++20* )

Garbage collector support (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
Défini dans l'en-tête <memory>
Compare deux shared_ptr objets.
template < class T, class U >

bool operator == ( const std:: shared_ptr < T > & lhs,

const std:: shared_ptr < U > & rhs ) noexcept ;
(1) (depuis C++11)
template < class T, class U >

bool operator ! = ( const std:: shared_ptr < T > & lhs,

const std:: shared_ptr < U > & rhs ) noexcept ;
(2) (depuis C++11)
(jusqu'à C++20)
template < class T, class U >

bool operator < ( const std:: shared_ptr < T > & lhs,

const std:: shared_ptr < U > & rhs ) noexcept ;
(3) (depuis C++11)
(jusqu'à C++20)
template < class T, class U >

bool operator > ( const std:: shared_ptr < T > & lhs,

const std:: shared_ptr < U > & rhs ) noexcept ;
(4) (depuis C++11)
(jusqu'à C++20)
template < class T, class U >

bool operator <= ( const std:: shared_ptr < T > & lhs,

const std:: shared_ptr < U > & rhs ) noexcept ;
(5) (depuis C++11)
(jusqu'à C++20)
template < class T, class U >

bool operator >= ( const std:: shared_ptr < T > & lhs,

const std:: shared_ptr < U > & rhs ) noexcept ;
(6) (depuis C++11)
(jusqu'à C++20)
template < class T, class U >

std:: strong_ordering operator <=> ( const std:: shared_ptr < T > & lhs,

const std:: shared_ptr < U > & rhs ) noexcept ;
(7) (depuis C++20)
Compare un shared_ptr avec un pointeur nul.
template < class T >
bool operator == ( const std:: shared_ptr < T > & lhs, std:: nullptr_t ) noexcept ;
(8) (depuis C++11)
template < class T >
bool operator == ( std:: nullptr_t , const std:: shared_ptr < T > & rhs ) noexcept ;
(9) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator ! = ( const std:: shared_ptr < T > & lhs, std:: nullptr_t ) noexcept ;
(10) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator ! = ( std:: nullptr_t , const std:: shared_ptr < T > & rhs ) noexcept ;
(11) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator < ( const std:: shared_ptr < T > & lhs, std:: nullptr_t ) noexcept ;
(12) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator < ( std:: nullptr_t , const std:: shared_ptr < T > & rhs ) noexcept ;
(13) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator > ( const std:: shared_ptr < T > & lhs, std:: nullptr_t ) noexcept ;
(14) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator > ( std:: nullptr_t , const std:: shared_ptr < T > & rhs ) noexcept ;
(15) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator <= ( const std:: shared_ptr < T > & lhs, std:: nullptr_t ) noexcept ;
(16) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator <= ( std:: nullptr_t , const std:: shared_ptr < T > & rhs ) noexcept ;
(17) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator >= ( const std:: shared_ptr < T > & lhs, std:: nullptr_t ) noexcept ;
(18) (depuis C++11)
(jusqu'à C++20)
template < class T >
bool operator >= ( std:: nullptr_t , const std:: shared_ptr < T > & rhs ) noexcept ;
(19) (depuis C++11)
(jusqu'à C++20)
template < class T >

std:: strong_ordering operator <=> ( const std:: shared_ptr < T > & lhs,

std:: nullptr_t ) noexcept ;
(20) (depuis C++20)

Compare deux objets shared_ptr<T> ou compare un shared_ptr<T> avec un pointeur nul.

Notez que les opérateurs de comparaison pour shared_ptr comparent simplement les valeurs des pointeurs ; les objets réels pointés ne sont pas comparés. Le fait d'avoir operator< défini pour shared_ptr permet aux shared_ptr d'être utilisés comme clés dans des conteneurs associatifs, comme std::map et std::set .

Les opérateurs < , <= , > , >= , et != sont synthétisés à partir de operator <=> et operator == respectivement.

(depuis C++20)

Table des matières

Paramètres

lhs - le shared_ptr de gauche à comparer
rhs - le shared_ptr de droite à comparer

Valeur de retour

1) lhs. get ( ) == rhs. get ( )
2) ! ( lhs == rhs )
3) std:: less < V > ( ) ( lhs. get ( ) , rhs. get ( ) ) , où V est le type de pointeur composite de std:: shared_ptr < T > :: element_type * et std:: shared_ptr < U > :: element_type * .
4) rhs < lhs
5) ! ( rhs < lhs )
6) ! ( lhs < rhs )
7) std:: compare_three_way { } ( x. get ( ) , y. get ( ) )
8) ! lhs
9) ! rhs
10) ( bool ) lhs
11) ( bool ) rhs
12) std:: less < std:: shared_ptr < T > :: element_type * > ( ) ( lhs. get ( ) , nullptr )
13) std:: less < std:: shared_ptr < T > :: element_type * > ( ) ( nullptr, rhs. get ( ) )
14) nullptr < lhs
15) rhs < nullptr
16) ! ( nullptr < lhs )
17) ! ( rhs < nullptr )
18) ! ( lhs < nullptr )
19) ! ( nullptr < rhs )
20) std:: compare_three_way { } ( x. get ( ) , static_cast < std:: shared_ptr < T > :: element_type * > ( nullptr ) )

Notes

Dans tous les cas, c'est le pointeur stocké (celui renvoyé par get() ) qui est comparé, plutôt que le pointeur géré (celui passé au destructeur lorsque use_count atteint zéro). Les deux pointeurs peuvent différer dans un shared_ptr créé en utilisant le constructeur d'aliasing.

Exemple

#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' // Depuis C++20
    // p1 et p2 pointent vers des emplacements mémoire différents, donc p1 != p2
        << "(p1 == p2)       : " << (p1 == p2) << '\n'
        << "(p1 < p2)        : " << (p1 < p2) << '\n'
        << "(p1 <=> p2) < 0  : " << ((p1 <=> p2) < 0) << '\n'   // Depuis C++20
        << "(p1 <=> p2) == 0 : " << ((p1 <=> p2) == 0) << '\n'; // Depuis C++20
}

Sortie possible :

(p1 == p1)       : true
(p1 <=> p1) == 0 : true
(p1 == p2)       : false
(p1 < p2)        : true
(p1 <=> p2) < 0  : true
(p1 <=> p2) == 0 : false

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Applied to Behavior as published Correct behavior
LWG 3427 C++20 operator<=>(shared_ptr, nullptr_t) était mal formé définition corrigée

Voir aussi

retourne le pointeur stocké
(fonction membre publique)