Copy assignment operator
Da cppreference.com.
![]() |
Questa pagina è stata tradotta in modo automatico dalla versione in ineglese della wiki usando Google Translate.
La traduzione potrebbe contenere errori e termini strani. Muovi il puntatore sopra al testo per vedere la versione originale. Puoi aiutarci a correggere gli gli errori. Per ulteriori istruzioni clicca qui. |
Un operatore di assegnamento per copia di
T
classe è un non-modello non statico funzione membro con il nome che prende operator= esattamente un parametro di tipo T, T&, const T&, volatile T& o const volatile T&. Un tipo con un operatore pubblico di assegnamento per copia è CopyAssignable
.Original:
A copy assignment operator of class
T
is a non-template non-static member function with the name operator= that takes exactly one parameter of type T, T&, const T&, volatile T&, or const volatile T&. A type with a public copy assignment operator is CopyAssignable
.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Sintassi
class_name & class_name :: operator= ( class_name )
|
(1) | (dal C++11) | |||||||
class_name & class_name :: operator= ( const class_name & )
|
(2) | (dal C++11) | |||||||
class_name & class_name :: operator= ( const class_name & ) = default;
|
(3) | (dal C++11) | |||||||
class_name & class_name :: operator= ( const class_name & ) = delete;
|
(4) | (dal C++11) | |||||||
[modifica] Spiegazione
# Dichiarazione tipica di un operatore di assegnamento copia quando copy-and-swap idiom può essere utilizzato
Original:
# Typical declaration of a copy assignment operator when copy-and-swap idiom can be used
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
# Dichiarazione tipica di un operatore di assegnamento copia quando idioma copy-and-swap non può essere utilizzato
Original:
# Typical declaration of a copy assignment operator when copy-and-swap idiom cannot be used
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
# Forzare un operatore di assegnamento per copia deve essere generato dal compilatore
Original:
# Forcing a copy assignment operator to be generated by the compiler
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
# Evitare l'assegnazione implicita copia
Original:
# Avoiding implicit copy assignment
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
L'operatore di assegnamento per copia viene chiamato ogni volta selezionato da sovraccarico risoluzione, ad esempio, quando un oggetto appare sul lato sinistro di un'espressione di assegnazione.
Original:
The copy assignment operator is called whenever selected by sovraccarico risoluzione, e.g. when an object appears on the left side of an assignment expression.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Implicitamente-ha dichiarato un operatore di assegnazione di copia
Se non definiti dall'utente operatori di assegnazione di copia sono forniti per un tipo di classe (struct, class o union), il compilatore sempre dichiarare un linea come membro pubblico della classe. Questo implicitamente dichiarato operatore di assegnamento per copia ha la T& T::operator=(const T&) forma se si verificano tutte le seguenti condizioni:
Original:
If no user-defined copy assignment operators are provided for a class type (struct, class, or union), the compiler will always declare one as an inline public member of the class. This implicitly-declared copy assignment operator has the form T& T::operator=(const T&) if all of the following is true:
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
- ogni base diretta
B
diT
ha un operatore di assegnamento per copia i cui parametri sonoB
oconst B&
o const volatile B&Original:each direct baseB
ofT
has a copy assignment operator whose parameters areB
orconst B&
or const volatile B&The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - ciascun membro non statico dati
M
diT
di tipo classe o una matrice di tipo di classe ha un operatore di assegnamento per copia i cui parametri sonoM
oconst M&
o const volatile M&Original:each non-static data memberM
ofT
of class type or array of class type has a copy assignment operator whose parameters areM
orconst M&
or const volatile M&The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
In caso contrario il implicitamente dichiarato operatore di assegnamento per copia è dichiarato come T& T::operator=(T&). (Si noti che a causa di queste regole, il implicitamente dichiarato-operatore di assegnamento per copia non può legarsi a un argomento volatili lvalue)
Original:
Otherwise the implicitly-declared copy assignment operator is declared as T& T::operator=(T&). (Note that due to these rules, the implicitly-declared copy assignment operator cannot bind to a volatile lvalue argument)
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
Una classe può avere più operatori di assegnazione di copia, ad esempio sia T& T::operator=(const T&) e T& T::operator=(T). Se alcuni definiti dall'utente operatori di assegnazione di copia sono presenti, l'utente può comunque forzare la generazione del gestore copia implicitamente dichiarato di assegnazione con la parola chiave
default
.Original:
A class can have multiple copy assignment operators, e.g. both T& T::operator=(const T&) and T& T::operator=(T). If some user-defined copy assignment operators are present, the user may still force the generation of the implicitly declared copy assignment operator with the keyword
default
.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
Poiché l'operatore di assegnamento per copia è sempre dichiarato per ogni classe, la classe di operatore di base di assegnazione è sempre nascosto. Se una dichiarazione con-viene utilizzato per portare in l'operatore di assegnamento dalla classe base, e il suo tipo di argomento potrebbe essere lo stesso del tipo di argomento dell'operatore di assegnazione implicita della classe derivata, la dichiarazione con-viene anche nascosta dalla implicita dichiarazione.
Original:
Because the copy assignment operator is always declared for any class, the base class assignment operator is always hidden. If a using-declaration is used to bring in the assignment operator from the base class, and its argument type could be the same as the argument type of the implicit assignment operator of the derived class, the using-declaration is also hidden by the implicit declaration.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Soppresso implicitamente dichiarato operatore di assegnazione di copia
Il implicitamente dichiarate o default operatore di assegnazione di copia per
T
classe è definita come cancellati in una qualsiasi delle seguenti condizioni:Original:
The implicitly-declared or defaulted copy assignment operator for class
T
is defined as deleted in any of the following is true:The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
-
T
ha un membro non statico di dati che è constOriginal:T
has a non-static data member that is constThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. -
T
ha un membro non statico di dati di un tipo di riferimento.Original:T
has a non-static data member of a reference type.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. -
T
ha un membro non statico di dati che non può essere copia-assegnato (ha eliminato, inaccessibile, o ambigua operatore di assegnamento copia)Original:T
has a non-static data member that cannot be copy-assigned (has deleted, inaccessible, or ambiguous copy assignment operator)The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. -
T
ha classe base diretta o virtuale che non può essere copia-assegnato (ha eliminato, inaccessibile, o ambigua operatore di assegnazione mossa)Original:T
has direct or virtual base class that cannot be copy-assigned (has deleted, inaccessible, or ambiguous move assignment operator)The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. -
T
ha una interfaccia user-dichiarato costruttore mossaOriginal:T
has a user-declared move constructorThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. -
T
ha dichiarato dall'utente operatore di assegnazione mossaOriginal:T
has a user-declared move assignment operatorThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Trivial copia operatore di assegnazione
Il implicitamente dichiarato-operatore di assegnamento copia per
T
classe è banale se tutte le seguenti condizioni:Original:
The implicitly-declared copy assignment operator for class
T
is trivial if all of the following is true:The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
-
T
non ha funzioni membro virtualiOriginal:T
has no virtual member functionsThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. -
T
non ha classi base virtualiOriginal:T
has no virtual base classesThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - L'operatore di assegnamento per copia selezionati per ogni base diretta di
T
è banaleOriginal:The copy assignment operator selected for every direct base ofT
is trivialThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - L'operatore di assegnamento per copia selezionati per ogni non-static tipo di classe (o una matrice di tipo di classe) memeber di
T
è banaleOriginal:The copy assignment operator selected for every non-static class type (or array of class type) memeber ofT
is trivialThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Un banale operatore di assegnamento copia crea una copia della rappresentazione dell'oggetto come per std::memmove. Tutti i tipi di dati compatibili con il linguaggio C (tipo POD) sono banalmente copia-assegnabile.
Original:
A trivial copy assignment operator makes a copy of the object representation as if by std::memmove. All data types compatible with the C language (POD types) are trivially copy-assignable.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Implicitamente definito operatore di assegnazione di copia
Se il implicitamente dichiarato operatore di assegnamento per copia non viene eliminato o banale, è definito (cioè corpo di una funzione viene generato e compilato) da parte del compilatore. Per i tipi union, l'assegnazione copia implicitamente definito copia la rappresentazione dell'oggetto (come da std::memmove). Per i non-sindacali tipi di classe (class e struct), l'operatore esegue membro-saggio di assegnamento per copia di basi dell'oggetto e membri non statici, nel loro ordine di inizializzazione, utilizzando, utilizzando built-in assegnazione per gli scalari e assegnazione copia per classe tipo.
Original:
If the implicitly-declared copy assignment operator is not deleted or trivial, it is defined (that is, a function body is generated and compiled) by the compiler. For union types, the implicitly-defined copy assignment copies the object representation (as by std::memmove). For non-union class types (class and struct), the operator performs member-wise copy assignment of the object's bases and non-static members, in their initialization order, using, using built-in assignment for the scalars and copy assignment operator for class types.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
La generazione del gestore copia implicitamente definito assegnazione è deprecated(dal C++11) se
T
ha un distruttore dichiarate dall'utente o dichiarate dall'utente costruttore di copia.Original:
The generation of the implicitly-defined copy assignment operator is deprecated(dal C++11) if
T
has a user-declared destructor or user-declared copy constructor.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Note
Se sia copiare e spostare gli operatori di assegnazione vengono forniti, la risoluzione dell'overload seleziona l'assegnazione mossa se l'argomento è un rvalue (o prvalue come una temporanea senza nome o xValue, come il risultato di std::move ), e seleziona l'assegnazione copia se l'argomento è lvalue' (dal nome di oggetto o di una funzione / operatore di ritorno valore assegnabile di riferimento). Se solo l'assegnazione copia sia presente, tutte le categorie di argomenti selezionarlo (il tempo che prende il suo argomento per valore o per riferimento a const, in quanto rvalues può legarsi a riferimenti const), che fa assegnamento per copia di riserva per l'assegnazione del movimento, quando si sposta non è più disponibile.
Original:
If both copy and move assignment operators are provided, overload resolution selects the move assignment if the argument is an rvalue (either prvalue such as a nameless temporary or xvalue such as the result of std::move), and selects the copy assignment if the argument is lvalue (named object or a function/operator returning lvalue reference). If only the copy assignment is provided, all argument categories select it (as long as it takes its argument by value or as reference to const, since rvalues can bind to const references), which makes copy assignment the fallback for move assignment, when move is unavailable.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Copia e scambiare
Operatore di assegnazione di copia può essere espressa in termini di costruttore di copia, distruttore, e lo swap () funzione membro, se fornito:
Original:
Copy assignment operator can be expressed in terms of copy constructor, destructor, and the swap() member function, if one is provided:
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
T& T::operator=(T arg) { // copy/move constructor is called to construct arg
swap(arg); // resources exchanged between *this and arg
return *this;
} // destructor is called to release the resources formerly held by *this
Per i non-lancio swap (), questo modulo fornisce garanzia eccezione forte. Per gli argomenti rvalue, questa forma richiama automaticamente il costruttore movimento, ed è a volte indicato come "operatore di assegnazione unificante" (come in, sia per copiare e spostare).
Original:
For non-throwing swap(), this form provides garanzia eccezione forte. For rvalue arguments, this form automatically invokes the move constructor, and is sometimes referred to as "unifying assignment operator" (as in, both copy and move).
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[modifica] Esempio
#include <iostream> #include <memory> struct A { int n; std::string s1; // user-defined copy assignment, copy-and-swap form A& operator=(A other) { std::cout << "copy assignment of A\n"; std::swap(n, other.n); std::swap(s1, other.s1); return *this; } }; struct B : A { std::string s2; // implicitly-defined copy assignment }; struct C { std::unique_ptr<int[]> data; std::size_t size; // non-copy-and-swap assignment C& operator=(const C& other) { // check for self-assignment if(&other == this) return *this; // reuse storage when possible if(size != other.size) data.reset(new int[other.size]); std::copy(&other.data[0], &other.data[0] + std::min(size, other.size), &data[0]); return *this; } // note: copy-and-swap would always cause a reallocation }; int main() { A a1, a2; std::cout << "a1 = a2 calls "; a1 = a2; // user-defined copy assignment B b1, b2; b2.s1 = "foo"; b2.s2 = "bar"; std::cout << "b1 = b2 calls "; b1 = b2; // implicitly-defined copy assignment std::cout << "b1.s1 = " << b1.s1 << " b1.s2 = " << b1.s2 << '\n'; }
Output:
a1 = a2 calls copy assignment of A b1 = b2 calls copy assignment of A b1.s1 = foo b1.s2 = bar