Udostępnij za pośrednictwem


IDiasession

Udostępnia kontekst zapytania dla symboli debugowania.

Składnia

IDiaSession : IUnknown

Metody

W poniższej tabeli przedstawiono metody IDiaSession.

Metoda Opis
IDiaSession::get_loadAddress Pobiera adres ładowania pliku wykonywalnego odpowiadającego symbolom w tym magazynie symboli. Jest to ta sama wartość, która została przekazana do metody put_loadAddress.
IDiaSession::put_loadAddress Ustawia adres ładowania pliku wykonywalnego, który odpowiada symbolom w tym magazynie symboli. Uwaga: Należy wywołać tę metodę po otrzymaniu obiektu IDiaSession i przed rozpoczęciem korzystania z obiektu.
IDiaSession::get_globalScope Pobiera odwołanie do zakresu globalnego.
IDiaSession::getEnumTables Pobiera moduł wyliczający dla wszystkich tabel zawartych w magazynie symboli.
IDiaSession::getSymbolsByAddr Pobiera moduł wyliczający dla wszystkich nazwanych symboli w statycznych lokalizacjach.
IDiaSession::findChildren Pobiera wszystkie elementy podrzędne określonego identyfikatora nadrzędnego zgodnego z nazwą i typem symbolu.
IDiaSession::findChildrenEx Pobiera wszystkie elementy podrzędne określonego identyfikatora nadrzędnego, które są zgodne z nazwą i typem symboli, w tym zoptymalizowanymi ustawieniami lokalnymi.
IDiaSession::findChildrenExByAddr Pobiera wszystkie elementy podrzędne określonego identyfikatora nadrzędnego, które są zgodne z nazwą i typem symboli, w tym zoptymalizowanymi ustawieniami lokalnymi, które zawierają lub znajdują się najbliżej określonego adresu.
IDiaSession::findChildrenExByVA Pobiera wszystkie elementy podrzędne określonego identyfikatora nadrzędnego, które są zgodne z nazwą i typem symboli, w tym zoptymalizowanymi ustawieniami lokalnymi, które zawierają określony adres wirtualny (VA, virtual address).
IDiaSession::findChildrenExByRVA Pobiera wszystkie elementy podrzędne określonego identyfikatora nadrzędnego, które są zgodne z nazwą i typem symbolu, w tym zoptymalizowanymi ustawieniami lokalnymi, które zawierają lub znajdują się najbliżej określonego względnego adresu wirtualnego (RVA).
IDiaSession::findSymbolByAddr Pobiera określony typ symbolu, który zawiera lub znajduje się najbliżej określonego adresu.
IDiaSession::findSymbolByRVA Pobiera określony typ symbolu, który zawiera lub znajduje się najbliżej określonego względnego adresu wirtualnego (RVA).
IDiaSession::findSymbolByVA Pobiera określony typ symbolu, który zawiera lub znajduje się najbliżej określonego adresu wirtualnego (VA).
IDiaSession::findSymbolByToken Pobiera symbol zawierający określony token metadanych.
IDiaSession::symsAreEquiv Sprawdza, czy dwa symbole są równoważne.
IDiaSession::symbolById Pobiera symbol według jego unikatowego identyfikatora.
IDiaSession::findSymbolByRVAEx Pobiera określony typ symbolu, który zawiera lub znajduje się najbliżej określonego względnego adresu wirtualnego i przesunięcia.
IDiaSession::findSymbolByVAEx Pobiera określony typ symbolu, który zawiera lub znajduje się najbliżej określonego adresu wirtualnego i przesunięcia.
IDiaSession::findFile Pobiera plik źródłowy przez compiland i nazwę.
IDiaSession::findFileById Pobiera plik źródłowy według identyfikatora pliku źródłowego.
IDiaSession::findLines Pobiera numery wierszy w określonym pliku compiland i identyfikatorze pliku źródłowego.
IDiaSession::findLinesByAddr Pobiera wiersze w określonym compiland, który zawiera określony adres.
IDiaSession::findLinesByRVA Pobiera wiersze w określonym współzadziale zawierającym określony względny adres wirtualny.
IDiaSession::findLinesByVA Znajduje informacje o numerze wiersza dla wierszy zawartych w określonym zakresie adresów.
IDiaSession::findLinesByLinenum Pobiera wiersze w określonym współzadziale według pliku źródłowego i numeru wiersza.
IDiaSession::findInjectedSource Pobiera źródło, które zostało umieszczone w magazynie symboli przez dostawców atrybutów lub innych składników procesu kompilacji.
IDiaSession::getEnumDebugStreams Pobiera wyliczona sekwencję strumieni danych debugowania.
IDiaSession::findInlineFramesByAddr Pobiera wyliczenie, które umożliwia klientowi iterowanie wszystkich wbudowanych ramek na danym adresie.
IDiaSession::findInlineFramesByRVA Pobiera wyliczenie, które umożliwia klientowi iterowanie wszystkich ramek wbudowanych na określonym względnym adresie wirtualnym (RVA).
IDiaSession::findInlineFramesByVA Pobiera wyliczenie, które umożliwia klientowi iterowanie wszystkich ramek wbudowanych na określonym adresie wirtualnym.
IDiaSession::findInlineeLines Pobiera wyliczenie, które umożliwia klientowi iterowanie przez informacje o numerze wiersza wszystkich funkcji, które są podkreślone, bezpośrednio lub pośrednio przez określony symbol nadrzędny.
IDiaSession::findInlineeLinesByAddr Pobiera wyliczenie, które umożliwia klientowi iterowanie przez informacje o numerze wiersza wszystkich funkcji wbudowanych, bezpośrednio lub pośrednio, przez określony symbol nadrzędny i są zawarte w określonym zakresie adresów.
IDiaSession::findInlineeLinesByRVA Pobiera wyliczenie, które umożliwia klientowi iterowanie za pośrednictwem informacji o numerze wiersza wszystkich funkcji, które są wbudowane, bezpośrednio lub pośrednio, przez określony symbol nadrzędny i są zawarte w określonym względnym adresie wirtualnym (RVA).
IDiaSession::findInlineeLinesByVA Pobiera wyliczenie, które umożliwia klientowi iterowanie za pośrednictwem informacji o numerze wiersza wszystkich funkcji, które są podkreślone, bezpośrednio lub pośrednio przez określony symbol nadrzędny i znajdują się w określonym adresie wirtualnym (VA).
IDiaSession::findInlineeLinesByLinenum Pobiera wyliczenie, które umożliwia klientowi iterowanie za pośrednictwem informacji o numerze wiersza wszystkich funkcji, które są wbudowane, bezpośrednio lub pośrednio, w określonym pliku źródłowym i numerze wiersza.
IDiaSession::findInlineesByName Pobiera wyliczenie, które umożliwia klientowi iterowanie przez informacje o numerze wiersza wszystkich wbudowanych funkcji, które są zgodne z określoną nazwą.
IDiaSession::findAcceleratorInlineesByLinenum Zwraca wyliczenie symboli dla ramek wbudowanych odpowiadających określonej lokalizacji źródłowej.
IDiaSession::findSymbolsForAcceleratorPointerTag Zwraca wyliczenie symboli dla zmiennej, która określona wartość tagu odpowiada funkcji wycinka akceleratora nadrzędnego.
IDiaSession::findSymbolsByRVAForAcceleratorPointerTag Biorąc pod uwagę odpowiadającą wartość tagu, ta metoda zwraca wyliczenie symboli zawartych w określonej funkcji wycinka akceleratora nadrzędnego w określonym względnym adresie wirtualnym.
IDiaSession::findAcceleratorInlineesByName Zwraca wyliczenie symboli dla ramek wbudowanych odpowiadających określonej wbudowanej nazwie funkcji.
IDiaSession::addressForVA Zwraca równoważny adres dla określonego adresu wirtualnego (VA).
IDiaSession::addressForRVA Zwraca równoważny adres dla określonego względnego adresu wirtualnego (RVA).
IDiaSession::findILOffsetsByAddr Pobiera wyliczenie, które umożliwia klientowi iterowanie po przesunięciach MSIL w określonym zakresie adresów.
IDiaSession::findILOffsetsByRVA Pobiera wyliczenie, które umożliwia klientowi iterowanie po przesunięciach MSIL w określonym zakresie względnego adresu wirtualnego (RVA).
IDiaSession::findILOffsetsByVA Pobiera wyliczenie, które umożliwia klientowi iterowanie po przesunięciach MSIL w określonym zakresie adresów wirtualnych.
IDiaSession::findInputAssemblyFiles Pobiera wyliczenie, które umożliwia klientowi iterowanie za pośrednictwem plików zestawu wejściowego platformy .NET Native.
IDiaSession::findInputAssembly Pobiera plik zestawu wejściowego platformy .NET Native według indeksu.
IDiaSession::findInputAssemblyById Pobiera plik zestawu wejściowego platformy .NET Native według unikatowego identyfikatora.
IDiaSession::getFuncMDTokenMapSize Pobiera rozmiar w bajtach mapy tokenu funkcji metadanych platformy .NET Native.
IDiaSession::getFuncMDTokenMap Pobiera zawartość mapy tokenów funkcji metadanych platformy .NET Native.
IDiaSession::getTypeMDTokenMapSize Pobiera rozmiar w bajtach mapy tokenu typu metadanych platformy .NET Native.
IDiaSession::getTypeMDTokenMap Pobiera zawartość mapy tokenów typu metadanych platformy .NET Native.
IDiaSession::getNumberOfFunctionFragments_VA Pobiera liczbę nieciągliwych fragmentów funkcji pod określonym adresem wirtualnym (VA).
IDiaSession::getNumberOfFunctionFragments_RVA Pobiera liczbę nieciągłych fragmentów funkcji pod określonym względnym adresem wirtualnym (RVA).
IDiaSession::getFunctionFragments_VA Pobiera adresy i długości nieciągliwych fragmentów funkcji pod określonym adresem wirtualnym (VA).
IDiaSession::getFunctionFragments_RVA Pobiera adresy i długości rozciągliwych fragmentów funkcji pod określonym względnym adresem wirtualnym (RVA).
IDiaSession::getExports Pobiera moduł wyliczający dla wszystkich wyeksportowanych symboli.
IDiaSession::getHeapAllocationSites Pobiera moduł wyliczający dla wszystkich symboli SymTagHeapAllocationSite.
IDiaSession::findInputAssemblyFile Pobiera plik zestawu wejściowego .NET Native, który jest elementem nadrzędnym określonego symbolu.

Uwagi

Należy wywołać metodę IDiaSession::put_loadAddress po utworzeniu obiektu IDiaSession — a wartość przekazana do metody put_loadAddress musi być inna niż zero — aby wszystkie właściwości wirtualnego adresu (VA) były dostępne. Adres ładowania pochodzi z dowolnego programu załadowanego pliku wykonywalnego debugowanego. Na przykład można wywołać funkcję Win32 GetModuleInformation, aby pobrać adres ładowania pliku wykonywalnego, biorąc pod uwagę uchwyt pliku wykonywalnego.

Przykład

W tym przykładzie pokazano, jak uzyskać interfejs IDiaSession w ramach ogólnej inicjalizacji zestawu SDK dostępu do interfejsu debugowania (DIA).

CComPtr<IDiaDataSource> pSource;
ComPtr<IDiaSession> psession;

void InitializeDIA(const char *szFilename)
{
    HRESULT hr = CoCreateInstance( CLSID_DiaSource,
                                   NULL,
                                   CLSCTX_INPROC_SERVER,
                                   __uuidof( IDiaDataSource ),
                                  (void **) &pSource);
    if (FAILED(hr))
    {
        Fatal("Could not CoCreate CLSID_DiaSource. Register msdia80.dll." );
    }
    wchar_t wszFilename[ _MAX_PATH ];
    mbstowcs( wszFilename,
              szFilename,
              sizeof( wszFilename )/sizeof( wszFilename[0] ) );
    if ( FAILED( pSource->loadDataFromPdb( wszFilename ) ) )
    {
        if ( FAILED( pSource->loadDataForExe( wszFilename, NULL, NULL ) ) )
        {
            Fatal( "loadDataFromPdb/Exe" );
        }
    }
    if ( FAILED( pSource->openSession( &psession ) ) )
    {
        Fatal( "openSession" );
    }
}

Wymagania

Nagłówek: Dia2.h

Biblioteka: diaguids.lib

BIBLIOTEKA DLL: msdia80.dll

Zobacz też