Método ICorProfilerCallback4::MovedReferences2
Chamado para relatar o novo layout de objetos no heap como resultado de uma coleta de lixo compactada. Esse método será chamado se o criador de perfil tiver implementado a interface ICorProfilerCallback4. Esse retorno de chamada substitui o método ICorProfilerCallback::MovedReferences, porque ele pode relatar intervalos maiores de objetos cujos comprimentos excedem o que pode ser expresso em um ULONG.
Sintaxe
HRESULT MovedReferences2(
[in] ULONG cMovedObjectIDRanges,
[in, size_is(cMovedObjectIDRanges)] ObjectID oldObjectIDRangeStart[] ,
[in, size_is(cMovedObjectIDRanges)] ObjectID newObjectIDRangeStart[] ,
[in, size_is(cMovedObjectIDRanges)] SIZE_T cObjectIDRangeLength[] );
Parâmetros
cMovedObjectIDRanges
[in] O número de blocos de objetos contíguos movidos como resultado da coleta de lixo compactada. Ou seja, o valor de cMovedObjectIDRanges
é o tamanho total de matrizes oldObjectIDRangeStart
, newObjectIDRangeStart
e cObjectIDRangeLength
.
Os três próximos argumentos de MovedReferences2
são matrizes paralelas. Em outras palavras, oldObjectIDRangeStart[i]
, newObjectIDRangeStart[i]
e cObjectIDRangeLength[i]
dizem respeito a um único bloco de objetos contíguos.
oldObjectIDRangeStart
[in] Uma matriz de valores de ObjectID
, cada um dos quais é o endereço inicial antigo (pré-coleta de lixo) de um bloco de objetos ativos contíguos na memória.
newObjectIDRangeStart
[in] Uma matriz de valores de ObjectID
, cada um dos quais é o endereço inicial novo (pós-coleta de lixo) de um bloco de objetos ativos contíguos na memória.
cObjectIDRangeLength
[in] Uma matriz de inteiros, cada um deles é o tamanho de um bloco de objetos contíguos na memória.
Um tamanho é especificado para cada bloco referenciado nas matrizes oldObjectIDRangeStart
e newObjectIDRangeStart
.
Comentários
Um coletor de lixo de compactação recupera a memória ocupada por objetos mortos e compactações que liberam espaço. Como resultado, objetos dinâmicos podem ser movidos dentro do heap e valores de ObjectID
distribuídos por notificações anteriores podem ser alterados.
Suponha que um valor de ObjectID
(oldObjectID
) esteja dentro do seguinte intervalo:
oldObjectIDRangeStart[i]
<= oldObjectID
<oldObjectIDRangeStart[i]
+ cObjectIDRangeLength[i]
Nesse caso, o deslocamento do início do intervalo até o início do objeto é o seguinte:
oldObjectID
- oldObjectRangeStart[i]
Para qualquer valor de i
que esteja no seguinte intervalo:
0 <= i
<cMovedObjectIDRanges
você pode calcular o novo ObjectID
da seguinte maneira:
newObjectID
= newObjectIDRangeStart[i]
+ (oldObjectID
– oldObjectIDRangeStart[i]
)
Nenhum dos valores de ObjectID
passados por MovedReferences2
é válido durante o próprio retorno de chamada, porque o coletor de lixo pode estar no processo de mover objetos de locais antigos para novos. Portanto, os criadores de perfis não devem tentar inspecionar objetos durante uma chamada MovedReferences2
. Um retorno de chamada ICorProfilerCallback2::GarbageCollectionFinished indica que todos os objetos foram movidos para seus novos locais e a inspeção pode ser executada.
Se o criador de perfil implementar ambas as interfaces ICorProfilerCallback e ICorProfilerCallback4, o método MovedReferences2
será chamado antes do método ICorProfilerCallback::MovedReferences, mas somente se o método MovedReferences2
retornar com êxito. Os profilers podem retornar um HRESULT que indica falha do método MovedReferences2
, para evitar chamar o segundo método.
Requisitos
Plataformas: confira Requisitos do sistema.
Cabeçalho: CorProf.idl, CorProf.h
Biblioteca: CorGuids.lib
Versões do .NET Framework: disponíveis desde 4.5