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.
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.
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 Practices topic 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 | 
|---|---|
| Intializes a new instance of the ComPtr class. Overloads provide default, copy, move, and conversion constructors. | |
| Deinitializes an instance of ComPtr. | 
Public Methods
| Name | Description | 
|---|---|
| Returns a ComPtr object that represents the interface identified by the specified template parameter. | |
| Returns a ComPtr object that represents the interface identified by the specified interface ID. | |
| Retrieves a weak reference to the current object. | |
| Associates this ComPtr with the interface type specified by the current template type parameter. | |
| Copies the current or specified interface associated with this ComPtr to the specified output pointer. | |
| Disassociates this ComPtr from the interface that it represents. | |
| Retrieves a pointer to the interface that is associated with this ComPtr. | |
| Retrieves the address of the ptr_ data member, which contains a pointer to the interface represented by this ComPtr. | |
| 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. | |
| Exchanges the interface managed by the current ComPtr with the interface managed by the specified ComPtr. | 
Protected Methods
| Name | Description | 
|---|---|
| Increments the reference count of the interface associated with this ComPtr. | |
| Performs a COM Release operation on the interface associated with this ComPtr. | 
Public Operators
| Name | Description | 
|---|---|
| Indicates whether or not a ComPtr is managing the object lifetime of an interface. | |
| Retrieves the address of the current ComPtr. | |
| Assigns a value to the current ComPtr. | |
| Retrieves a pointer to the type specified by the current template parameter. | |
| Indicates whether two ComPtr objects are equal. | |
| Indicates whether two ComPtr objects are not equal. | 
Protected Data Members
| Name | Description | 
|---|---|
| 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