Classe CLocalHeap
Essa classe implementa IAtlMemMgr usando as funções de heap locais do Win32.
Importante
Essa classe e os respectivos membros não podem ser usados em aplicativos executados no Windows Runtime.
Sintaxe
class CLocalHeap : public IAtlMemMgr
Membros
Métodos públicos
Nome | Descrição |
---|---|
CLocalHeap::Allocate | Chame esse método para alocar um bloco de memória. |
CLocalHeap::Free | Chame esse método para liberar um bloco de memória alocado por esse gerenciador de memória. |
CLocalHeap::GetSize | Chame esse método para ter o tamanho alocado de um bloco de memória alocado por esse gerenciador de memória. |
CLocalHeap::Reallocate | Chame esse método para realocar a memória alocada por esse gerenciador de memória. |
Comentários
CLocalHeap
implementa funções de alocação de memória usando as funções de heap locais do Win32.
Observação
As funções de heap locais são mais lentas do que outras funções de gerenciamento de memória e não fornecem tantos recursos. Portanto, novos aplicativos devem usar as funções de heap. Eles estão disponíveis na classe CWin32Heap.
Exemplo
Consulte o exemplo de IAtlMemMgr.
Hierarquia de herança
IAtlMemMgr
CLocalHeap
Requisitos
Cabeçalho: atlmem.h
CLocalHeap::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 de retorno
Retorna um ponteiro para o início do bloco de memória recém-alocado.
Comentários
Chame CLocalHeap::Free ou CLocalHeap::Reallocate para liberar a memória alocada por esse método.
Implementado usando LocalAlloc com um parâmetro de sinalizador de LMEM_FIXED.
CLocalHeap::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 LocalFree.
CLocalHeap::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 de retorno
Retorna o tamanho do bloco de memória alocado em bytes.
Comentários
Implementado usando LocalSize.
CLocalHeap::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 de retorno
Retorna um ponteiro para o início do bloco de memória recém-alocado.
Comentários
Chame CLocalHeap::Free para liberar a memória alocada por esse método.
Implementado usando LocalReAlloc.
Confira também
Visão geral da aula
Classe CComHeap
Classe CWin32Heap
Classe CGlobalHeap
Classe de CCRTHeap
Classe IAtlMemMgr