std::shared_ptr
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. |
Elemento definito nell'header <memory>
|
||
template< class T > class shared_ptr; |
(dal C++11) | |
std::shared_ptr
è un puntatore intelligente che mantiene la proprietà condivisa di un oggetto tramite un puntatore. Diversi oggetti shared_ptr
può possedere lo stesso oggetto; l'oggetto viene distrutto quando l'ultimo shared_ptr
rimasto che punta ad esso viene distrutto o resettato. L'oggetto viene distrutto con delete-expression o un deleter personalizzato che viene fornito allo shared_ptr
durante la costruzione.Original:
std::shared_ptr
is a smart pointer that retains shared ownership of an object through a pointer. Several shared_ptr
objects may own the same object; the object is destroyed when the last remaining shared_ptr
pointing to it is destroyed or reset. The object is destroyed using delete-expression or a custom deleter that is supplied to shared_ptr
during construction.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.
Un
shared_ptr
può anche possedere nessun oggetto, nel qual caso si parla di vuoto.Original:
A
shared_ptr
may also own no objects, in which case it is called empty.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.
shared_ptr
soddisfa i requisiti della CopyConstructible
e CopyAssignable
.Original:
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] Membri tipi
Membro tipo
Original: Member type The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
Definition |
element_type | T |
[modifica] Membri funzioni
constructs new shared_ptr (metodo pubblico) | |
distrugge l'oggetto di proprietà, se non di più shared_ptr s collegamento ad esso Original: destructs the owned object if no more shared_ptr s link to it The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
assegna il shared_ptr Original: assigns the shared_ptr The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
Original: Modifiers The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | |
sostituisce l'oggetto gestito Original: replaces the managed object The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
scambia gli oggetti gestiti Original: swaps the managed objects The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
Original: Observers The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | |
restituisce un puntatore all'oggetto gestito Original: returns a pointer to the managed object The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
dereferenzia puntatore all'oggetto gestito Original: dereferences pointer to the managed object The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
restituisce il numero di oggetti shared_ptr riferiscono allo stesso oggetto gestito Original: returns the number of shared_ptr objects referring to the same managed object The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
Verifica se l'oggetto gestito è gestito solo dall'istanza shared_ptr corrente Original: checks whether the managed object is managed only by the current shared_ptr instance The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
controlla se è associato oggetto gestito Original: checks if there is associated managed object The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) | |
fornisce proprietario a base di ordinazione di puntatori condivisi Original: provides owner-based ordering of shared pointers The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (metodo pubblico) |
[modifica] Non membri funzioni
crea un puntatore condiviso che gestisce un nuovo oggetto Original: creates a shared pointer that manages a new object The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
crea un puntatore condiviso che gestisce un nuovo oggetto allocato con un allocatore Original: creates a shared pointer that manages a new object allocated using an allocator The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
vale static_cast, dynamic_cast const_cast o al tipo di oggetto gestito Original: The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
restituisce il deleter del tipo specificato, se di proprietà Original: returns the deleter of specified type, if owned The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
confronta con un altro o con shared_ptr nullptr Original: compares with another shared_ptr or with nullptr The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
emette il valore del puntatore gestito un flusso di output Original: outputs the value of the managed pointer to an output stream The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
(C++11) |
specializzata l'algoritmo std::swap Original: specializes the std::swap algorithm The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) |
specializzata operazioni atomiche Original: specializes atomic operations The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) |
[modifica] Helper classi
(C++11) |
sostegno hash per std::shared_ptr Original: hash support for std::shared_ptr The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (classe modello di specializzazione) |
[modifica] Note di attuazione
In una tipica implementazione, std::shared_ptr contiene solo due puntatori:
Original:
In a typical implementation, std::shared_ptr holds only two pointers:
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.
- un puntatore dell'oggetto di riferimentoOriginal:a pointer to the referenced objectThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - un puntatore al blocco di controllo'Original:a pointer to control blockThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Se il blocco di controllo è un oggetto allocati dinamicamente, che contiene:
Original:
Where the control block is a dynamically-allocated object that holds:
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.
- un puntatore all'oggetto gestito o l'oggetto gestito in séOriginal:a pointer to the managed object or the managed object itselfThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - il deleterOriginal:the deleterThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - l'allocatoreOriginal:the allocatorThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - il numero di
shared_ptr
s che possiedono l'oggetto gestitoOriginal:the number ofshared_ptr
s that own the managed objectThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - il numero di
weak_ptr
s che fanno riferimento all'oggetto gestitoOriginal:the number ofweak_ptr
s that refer to the managed objectThe text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Quando
shared_ptr
viene creato chiamando std::make_shared o std::allocate_shared, il blocco di controllo contiene l'oggetto gestito direttamente, come un membro dati. Quando shared_ptr
viene creato chiamando un costruttore, un puntatore viene memorizzato.Original:
When
shared_ptr
is created by calling std::make_shared or std::allocate_shared, the control block holds the managed object directly, as a data member. When shared_ptr
is created by calling a constructor, a pointer is stored.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.
Il puntatore in possesso del
shared_ptr
è direttamente quello restituito dalla get()
, mentre il puntatore / oggetto in possesso del blocco di controllo è quello che sarà cancellato quando il numero di proprietari condivisi raggiunge lo zero: queste indicazioni non sono necessariamente uguali.Original:
The pointer held by the
shared_ptr
directly is the one returned by get()
, while the pointer/object held by the control block is the one that will be deleted when the number of shared owners reaches zero: these pointers are not necessarily equal.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.
Il distruttore della
shared_ptr
decrementa il numero dei proprietari condivisi del blocco di controllo, e se questo arriva a zero, il blocco di controllo chiama il distruttore dell'oggetto gestito, ma il blocco di controllo non si rilasciare fino a quando il contatore raggiunge lo zero std::weak_ptr pure.Original:
The destructor of
shared_ptr
decrements the number of shared owners of the control block, and if that reaches zero, the control block calls the destructor of the managed object, but the control block does not deallocate itself until the std::weak_ptr counter reaches zero as well.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.