Compartilhar via


Implementando CComObject, CComAggObject, e CComPolyObject

O modelo classe CComObject, CComAggObject, e CComPolyObject sempre é a maioria das classes derivadas na cadeia de herança.É de sua responsabilidade manipular todos os métodos em IUnknown: QueryInterface, AddRef, e Versão.Além de isso, CComAggObject e CComPolyObject (quando usado para objetos agregados) fornecem contagem de referência e semântica especiais de QueryInterface necessárias para o desconhecido interno.

Se CComObject, CComAggObject, ou CComPolyObject são usados depende se você não declarar um (ou qualquer macros) dos seguintes:

Macro

Efeito

DECLARE_NOT_AGGREGATABLE

Sempre use CComObject.

DECLARE_AGGREGATABLE

Usa CComAggObject se o objeto é agregado e CComObject se não é.CComCoClass contém esse macro se nenhum dos macros de DECLARE_*_AGGREGATABLE são declarados em sua classe, isso será o padrão.

DECLARE_ONLY_AGGREGATABLE

Sempre use CComAggObject.Retorna um erro se o objeto não é agregado.

DECLARE_POLY_AGGREGATABLE

ATL cria uma instância de CComPolyObject<CYourClass> quando IClassFactory::CreateInstance é chamado.Durante a criação, o valor de desconhecido externo é verificado.Se é NULO, IUnknown é implementado para um objeto nonaggregated.Se o não externo não é NULO, IUnknown é implementado para um objeto agregado.

A vantagem de usar CComAggObject e CComObject é a implementação de IUnknown é otimizado para o tipo de objeto que está sendo criado.Por exemplo, um objeto nonaggregated precisa apenas uma contagem de referência, quando um objeto agregado necessário uma contagem de referência para o desconhecido interno e um ponteiro para o desconhecido externo.

A vantagem de usar CComPolyObject é que você evita ter CComAggObject e CComObject em seu módulo para manipular o caso agregados e nonaggregated.Identificadores únicos de objeto de CComPolyObject ambos os casos.Isso significa que apenas uma cópia de vtable e uma cópia das funções existem no seu módulo.Se seu vtable é grande, isso pode reduzir significativamente o tamanho do módulo.Em o entanto, se seu vtable é pequeno, usar CComPolyObject pode resultar em um tamanho maior um pouco de módulo porque não é otimizado para um objeto agregado ou nonaggregated, como é CComAggObject e CComObject.

Consulte também

Referência

Fundamentos de objetos COM de ATL

Outros recursos

Macros de fábrica de distribuição e uma classe