Método IXCLRDataProcess::FollowStub
Dado um endereço que é um stub CLR (e potencialmente estado de um seguimento anterior), determine o próximo endereço de execução no qual verificar se o stub foi encerrado.
NOTA: Este método está obsoleto. Os chamadores devem utilizar IXCLRDataProcess::FollowStub2
sempre que disponível. Tal está disponível se a revisão do processo conforme retornada por IXCLRDataProcess::Request
for pelo menos 7.
Nota
Esta API foi originalmente projetada para uso interno no tempo de execução. Embora agora seja suportado para uso de terceiros 3rd, recomendamos trabalhar com ICorDebug
e ICorProfiler
APIs quando possível.
Sintaxe
HRESULT FollowStub(
[in] ULONG32 inFlags,
[in] CLRDATA_ADDRESS inAddr,
[in] CLRDATA_FOLLOW_STUB_BUFFER *inBuffer,
[out] CLRDATA_ADDRESS *outAddr,
[out] CLRDATA_FOLLOW_STUB_BUFFER *outBuffer,
[out] ULONG32 *outFlags
);
Parâmetros
inFlags
[em] Um conjunto de bandeiras descrevendo como seguir o esboço. Este deve ser um valor da CLRDataFollowStubInFlag
enumeração que atualmente contém apenas um valor: CLRDATA_FOLLOW_STUB_DEFAULT (0).
inAddr
[em] O endereço do esboço a seguir
inBuffer
[em] Um buffer de dados opaco usado internamente para manter o estado de andar uma cadeia de stubs. Isso deve ser NULL na chamada inicial para o FollowStub
método.
outAddr
[saídas] O próximo endereço de execução determinado a partir de seguir o esboço.
outBuffer
[saídas] Um buffer de dados opaco usado internamente para manter o estado de andar uma cadeia de stubs.
outFlags
[saídas] Um conjunto de bandeiras que descrevem o resultado de seguir o esboço. Este é um valor da CLRDataFollowStubOutFlag
enumeração. Se o valor for CLRDATA_FOLLOW_STUB_INTERMEDIATE
(0), o resultado é uma etapa intermediária no seguimento do stub e o chamador pode chamar FollowStub novamente. Se o valor for CLRDATA_FOLLOW_STUB_EXIT
(1), este é o fim da cadeia de stub e o é o outAddr
endereço de execução no final da cadeia.
Observações
Um determinado endereço pode ser determinado como sendo um stub ou não através do uso do IXCLRDataProcess::GetAddressType
método que retorna um tipo de CLRDATA_ADDRESS_RUNTIME_MANAGED_STUB
ou CLRDATA_ADDRESS_RUNTIME_UNMANAGED_STUB
.
O método fornecido faz parte da IXCLRDataProcess
interface e corresponde ao 47º slot da tabela de métodos virtuais.
Requisitos
Plataformas: Consulte Requisitos do sistema. Cabeçalho: Nenhuma Biblioteca: Nenhuma Versões do .NET Framework: Disponível desde 4.7