Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Crea una instancia de un objeto COM dentro de com::ptr.
void CreateInstance(
System::String ^ progid,
LPUNKNOWN pouter,
DWORD cls_context
);
void CreateInstance(
System::String ^ progid,
LPUNKNOWN pouter
);
void CreateInstance(
System::String ^ progid
);
void CreateInstance(
const wchar_t * progid,
LPUNKNOWN pouter,
DWORD cls_context
);
void CreateInstance(
const wchar_t * progid,
LPUNKNOWN pouter
);
void CreateInstance(
const wchar_t * progid
);
void CreateInstance(
REFCLSID rclsid,
LPUNKNOWN pouter,
DWORD cls_context
);
void CreateInstance(
REFCLSID rclsid,
LPUNKNOWN pouter
);
void CreateInstance(
REFCLSID rclsid
);
Parámetros
progid
Una cadena de ProgID .pouter
Puntero a la interfaz IUnknown del objeto global (el IUnknown que controla).Si pouter no se especifica, se utiliza NULL .cls_context
Contexto en el que el código que administra el objeto recién creado se ejecutará.Los valores se toman de la enumeración de CLSCTX .Si cls_context no se especifica, se utiliza el valor CLSCTX_ALL.rclsid
CLSID asociado con los datos y el código que se usarán para crear el objeto.
Excepciones
Si com::ptr ya posee una referencia a un objeto COM, CreateInstance produce InvalidOperationException.
Este las llamadas de función CoCreateInstance y utilizan ThrowExceptionForHR para convertir cualquier error HRESULT a una excepción adecuada.
Comentarios
CreateInstance utiliza CoCreateInstance para crear una nueva instancia del objeto especificado, identificada de ProgID o de CLSID.com::ptr hace referencia al objeto recién creado y automáticamente libera todas las referencias que pertenecen a la destrucción.
Ejemplo
Este ejemplo implementa una clase CLR que utilice com::ptr para ajustar su objeto de IXMLDOMDocument miembro privado.Los constructores de clase usan dos formas de CreateInstance para crear el objeto document de ProgID o de CLSID más un CLSCTX.
// comptr_createinstance.cpp
// compile with: /clr /link msxml2.lib
#include <msxml2.h>
#include <msclr\com\ptr.h>
#import <msxml3.dll> raw_interfaces_only
using namespace System;
using namespace System::Runtime::InteropServices;
using namespace msclr;
// a ref class that uses a com::ptr to contain an
// IXMLDOMDocument object
ref class XmlDocument {
public:
// construct the internal com::ptr with a null interface
// and use CreateInstance to fill it
XmlDocument(String^ progid) {
m_ptrDoc.CreateInstance(progid);
}
XmlDocument(REFCLSID clsid, DWORD clsctx) {
m_ptrDoc.CreateInstance(clsid, NULL, clsctx);
}
// note that the destructor will call the com::ptr destructor
// and automatically release the reference to the COM object
private:
com::ptr<IXMLDOMDocument> m_ptrDoc;
};
// use the ref class to handle an XML DOM Document object
int main() {
try {
// create the class from a progid string
XmlDocument doc1("Msxml2.DOMDocument.3.0");
// or from a clsid with specific CLSCTX
XmlDocument doc2(CLSID_DOMDocument30, CLSCTX_INPROC_SERVER);
}
catch (Exception^ e) {
Console::WriteLine(e);
}
}
Requisitos
archivo de encabezado <msclr \ COM \ ptr.h>
Msclr::com deespacio de nombres