Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
The new home for Visual Studio documentation is Visual Studio 2017 Documentation on docs.microsoft.com.
The latest version of this topic can be found at ComPtr Class.
Creates a smart pointer type that represents the interface specified by the template parameter. ComPtr automatically maintains a reference count for the underlying interface pointer and releases the interface when the reference count goes to zero.
Syntax
template <  
   typename T  
>  
class ComPtr;  
  
template<  
   class U  
>  
friend class ComPtr;  
Parameters
T
The interface that the ComPtr represents.
U
A class to which the current ComPtr is a friend. (The template that uses this parameter is protected.)
Remarks
ComPtr<> declares a type that represents the underlying interface pointer. Use ComPtr<> to declare a variable and then use the arrow member-access operator (->) to access an interface member function.
For more information about smart pointers, see the "COM Smart Pointers" subsection of the COM Coding Practicestopic in the MSDN Library.
Members
Public Typedefs
| Name | Description | 
|---|---|
InterfaceType | 
A synonym for the type specified by the T template parameter. | 
Public Constructors
| Name | Description | 
|---|---|
| ComPtr::ComPtr Constructor | Intializes a new instance of the ComPtr class. Overloads provide default, copy, move, and conversion constructors. | 
| ComPtr::~ComPtr Destructor | Deinitializes an instance of ComPtr. | 
Public Methods
| Name | Description | 
|---|---|
| ComPtr::As Method | Returns a ComPtr object that represents the interface identified by the specified template parameter. | 
| ComPtr::AsIID Method | Returns a ComPtr object that represents the interface identified by the specified interface ID. | 
| ComPtr::AsWeak Method | Retrieves a weak reference to the current object. | 
| ComPtr::Attach Method | Associates this ComPtr with the interface type specified by the current template type parameter. | 
| ComPtr::CopyTo Method | Copies the current or specified interface associated with this ComPtr to the specified output pointer. | 
| ComPtr::Detach Method | Disassociates this ComPtr from the interface that it represents. | 
| ComPtr::Get Method | Retrieves a pointer to the interface that is associated with this ComPtr. | 
| ComPtr::GetAddressOf Method | Retrieves the address of the ptr_ data member, which contains a pointer to the interface represented by this ComPtr. | 
| ComPtr::ReleaseAndGetAddressOf Method | Releases the interface associated with this ComPtr and then retrieves the address of the ptr_ data member, which contains a pointer to the interface that was released. | 
| ComPtr::Reset | Releases all references for the pointer to the interface that is associated with this ComPtr. | 
| ComPtr::Swap Method | Exchanges the interface managed by the current ComPtr with the interface managed by the specified ComPtr. | 
Protected Methods
| Name | Description | 
|---|---|
| ComPtr::InternalAddRef Method | Increments the reference count of the interface associated with this ComPtr. | 
| ComPtr::InternalRelease Method | Performs a COM Release operation on the interface associated with this ComPtr. | 
Public Operators
| Name | Description | 
|---|---|
| ComPtr::operator Microsoft::WRL::Details::BoolType Operator | Indicates whether or not a ComPtr is managing the object lifetime of an interface. | 
| ComPtr::operator& Operator | Retrieves the address of the current ComPtr. | 
| ComPtr::operator= Operator | Assigns a value to the current ComPtr. | 
| ComPtr::operator-> Operator | Retrieves a pointer to the type specified by the current template parameter. | 
| ComPtr::operator== Operator | Indicates whether two ComPtr objects are equal. | 
| ComPtr::operator!= Operator | Indicates whether two ComPtr objects are not equal. | 
Protected Data Members
| Name | Description | 
|---|---|
| ComPtr::ptr_ Data Member | Contains a pointer to the interface that is associated with, and managed by this ComPtr. | 
Inheritance Hierarchy
ComPtr
Requirements
Header: client.h
Namespace: Microsoft::WRL