CAutoPtr, classe
Cette classe représente un objet de pointeur intelligent.
Important
Cette classe et ses membres ne peuvent pas être utilisés dans les applications qui s'exécutent dans les fenêtres d'exécution.
template<
typename T
>
class CAutoPtr
Paramètres
- T
Le type pointeur.
Membres
Constructeurs publics
Nom |
Description |
---|---|
Constructeur. |
|
Le destructeur. |
Méthodes publiques
Nom |
Description |
---|---|
Appelez cette méthode pour prendre la propriété d'un pointeur existant. |
|
Appelez cette méthode pour libérer la propriété d'un pointeur. |
|
Appelez cette méthode pour supprimer un objet vers lequel pointe CAutoPtr. |
Opérateurs publics
Nom |
Description |
---|---|
l'opérateur de cast. |
|
l'opérateur d'assignation. |
|
L'opérateur de pointeur vers membre. |
Données membres publiques
Nom |
Description |
---|---|
La variable de membre de pointeur. |
Notes
Cette classe fournit des méthodes pour créer et gérer un pointeur intelligent, qui permet de se protéger contre des fuites de mémoire en libérant automatiquement des ressources lorsqu'il se situe hors de portée.
De plus, le constructeur de copie d'CAutoPtr et l'opérateur d'assignation transfèrent la propriété du pointeur, copiant le pointeur de source au pointeur de destination et en plaçant le pointeur de source avec la valeur NULL. Il est donc impossible d'avoir deux objets chacun d' CAutoPtr qui stocke le même pointeur, et cela réduit la possibilité de supprimer le même pointeur deux fois.
CAutoPtr simplifie également la création de collections de pointeurs. Au lieu de dériver une classe de collection et de remplacer le destructeur, il est plus simple de créer une collection d'objets CAutoPtr . Lorsque la collection est désactivée, les objets d' CAutoPtr aura pour résultat de la portée et se supprimeront automatiquement.
CHeapPtr et les variantes fonctionnent de la même façon qu' CAutoPtr, sauf qu'ils allouent et la mémoire disponible à l'aide de le tas différent s'exécute au lieu du C++ nouveau et des opérateurs de supprimer . CAutoVectorPtr est semblable à CAutoPtr, la seule différence est qu'il utilise vector new[] et vector delete[] pour allouer et libérer de la mémoire.
Voir aussi CAutoPtrArray et le CAutoPtrList lorsque des tableaux ou des listes de pointeurs intelligents sont requises.
Configuration requise
Header: atlbase.h
Exemple
// A simple class for demonstration purposes
class MyClass
{
int iA;
int iB;
public:
MyClass(int a, int b);
void Test();
};
MyClass::MyClass(int a, int b)
{
iA = a;
iB = b;
}
void MyClass::Test()
{
ATLASSERT(iA == iB);
}
// A simple function
void MyFunction(MyClass* c)
{
c->Test();
}
int UseMyClass()
{
// Create an object of MyClass.
MyClass *pMyC = new MyClass(1, 1);
// Create a CAutoPtr object and have it take
// over the pMyC pointer by calling Attach.
CAutoPtr<MyClass> apMyC;
apMyC.Attach(pMyC);
// The overloaded -> operator allows the
// CAutoPtr object to be used in place of the pointer.
apMyC->Test();
// Assign a second CAutoPtr, using the = operator.
CAutoPtr<MyClass> apMyC2;
apMyC2 = apMyC;
// The casting operator allows the
// object to be used in place of the pointer.
MyFunction(pMyC);
MyFunction(apMyC2);
// Detach breaks the association, so after this
// call, pMyC is controlled only by apMyC.
apMyC2.Detach();
// CAutoPtr destroys any object it controls when it
// goes out of scope, so apMyC destroys the object
// pointed to by pMyC here.
return 0;
}