operator==, !=, <, <=, >, >=, <=> (std::shared_ptr)
|
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,
|
(1) | (depuis C++11) |
|
template
<
class
T,
class
U
>
bool
operator
!
=
(
const
std::
shared_ptr
<
T
>
&
lhs,
|
(2) |
(depuis C++11)
(jusqu'à C++20) |
|
template
<
class
T,
class
U
>
bool
operator
<
(
const
std::
shared_ptr
<
T
>
&
lhs,
|
(3) |
(depuis C++11)
(jusqu'à C++20) |
|
template
<
class
T,
class
U
>
bool
operator
>
(
const
std::
shared_ptr
<
T
>
&
lhs,
|
(4) |
(depuis C++11)
(jusqu'à C++20) |
|
template
<
class
T,
class
U
>
bool
operator
<=
(
const
std::
shared_ptr
<
T
>
&
lhs,
|
(5) |
(depuis C++11)
(jusqu'à C++20) |
|
template
<
class
T,
class
U
>
bool
operator
>=
(
const
std::
shared_ptr
<
T
>
&
lhs,
|
(6) |
(depuis C++11)
(jusqu'à C++20) |
|
template
<
class
T,
class
U
>
std::
strong_ordering
operator
<=>
(
const
std::
shared_ptr
<
T
>
&
lhs,
|
(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,
|
(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
|
(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
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) |