Classe CComHeap
Essa classe implementa IAtlMemMgr
usando as funções de alocação de memória COM.
Importante
Essa classe e os respectivos membros não podem ser usados em aplicativos executados no Windows Runtime.
Sintaxe
class CComHeap : public IAtlMemMgr
Membros
Métodos públicos
Nome | Descrição |
---|---|
CComHeap::Allocate |
Chame esse método para alocar um bloco de memória. |
CComHeap::Free |
Chame esse método para liberar um bloco de memória alocado por esse gerenciador de memória. |
CComHeap::GetSize |
Chame esse método para ter o tamanho alocado de um bloco de memória alocado por esse gerenciador de memória. |
CComHeap::Reallocate |
Chame esse método para realocar a memória alocada por esse gerenciador de memória. |
Comentários
CComHeap
implementa funções de alocação de memória usando as funções de alocação COM, incluindo CoTaskMemAlloc
, CoTaskMemFree
, IMalloc::GetSize
e CoTaskMemRealloc
. A quantidade máxima de memória que pode ser alocada é igual a INT_MAX
(2147483647) bytes.
Exemplo
Confira o exemplo de IAtlMemMgr
.
Hierarquia de herança
IAtlMemMgr
CComHeap
Requisitos
Cabeçalho: ATLComMem.h
CComHeap::Allocate
Chame esse método para alocar um bloco de memória.
virtual __declspec(allocator) void* Allocate(size_t nBytes) throw();
Parâmetros
nBytes
O número solicitado de bytes no novo bloco de memória.
Valor retornado
Retorna um ponteiro para o início do bloco de memória recém-alocado.
Comentários
Chame CComHeap::Free
uCComHeap::Reallocate
para liberar a memória alocada por esse método.
Implementado usando CoTaskMemAlloc
.
CComHeap::Free
Chame esse método para liberar um bloco de memória alocado por esse gerenciador de memória.
virtual void Free(void* p) throw();
Parâmetros
p
Ponteiro para a memória alocada anteriormente por esse gerenciador de memória. NULL é um valor válido e não faz nada.
Comentários
Implementado usando CoTaskMemFree
.
CComHeap::GetSize
Chame esse método para ter o tamanho alocado de um bloco de memória alocado por esse gerenciador de memória.
virtual size_t GetSize(void* p) throw();
Parâmetros
p
Ponteiro para a memória alocada anteriormente por esse gerenciador de memória.
Valor retornado
Retorna o tamanho do bloco de memória alocado em bytes.
Comentários
Implementado usando IMalloc::GetSize
.
CComHeap::Reallocate
Chame esse método para realocar a memória alocada por esse gerenciador de memória.
virtual __declspec(allocator) void* Reallocate(void* p, size_t nBytes) throw();
Parâmetros
p
Ponteiro para a memória alocada anteriormente por esse gerenciador de memória.
nBytes
O número solicitado de bytes no novo bloco de memória.
Valor retornado
Retorna um ponteiro para o início do bloco de memória recém-alocado.
Comentários
Chame CComHeap::Free
para liberar a memória alocada por esse método.
Implementado usando CoTaskMemRealloc
.
Confira também
Exemplo de DynamicConsumer
Visão geral da aula
Classe CWin32Heap
Classe CLocalHeap
Classe CGlobalHeap
Classe CCRTHeap
Classe IAtlMemMgr