Partilhar via


Consultando o arquivo .Pdb

Um arquivo de banco de dados do programa (extensão .pdb) é um arquivo binário que contém informações de depuração simbólicas e de tipo coletadas ao longo da compilação e da vinculação do projeto. Um arquivo PDB é criado quando você compila um programa C/C++ com /ZI ou /Zi ou um programa Visual Basic, Visual C#ou JScript com a opção /debug. Os arquivos de objeto contêm referências ao arquivo .pdb para informações de depuração. Para obter mais informações sobre arquivos pdb, confira Arquivos PDB. Um aplicativo DIA pode usar as etapas gerais a seguir para obter detalhes sobre os vários símbolos, objetos e elementos de dados dentro de uma imagem executável.

Para consultar o arquivo .pdb

  1. Adquira uma fonte de dados criando uma interface IDiaDataSource.

    CComPtr<IDiaDataSource> pSource;
    hr = CoCreateInstance( CLSID_DiaSource,
                           NULL,
                           CLSCTX_INPROC_SERVER,
                           __uuidof( IDiaDataSource ),
                          (void **) &pSource);
    
    if (FAILED(hr))
    {
        Fatal("Could not CoCreate CLSID_DiaSource. Register msdia80.dll." );
    }
    
  2. Chame IDiaDataSource::loadDataFromPdb ou IDiaDataSource::loadDataForExe para carregar as informações de depuração.

    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" );
        }
    }
    
  3. Chame IDiaDataSource::openSession para abrir uma IDiaSession a fim de obter acesso às informações de depuração.

    CComPtr<IDiaSession> psession;
    if ( FAILED( pSource->openSession( &psession ) ) )
    {
        Fatal( "openSession" );
    }
    
  4. Use os métodos IDiaSession para consultar os símbolos na fonte de dados.

    CComPtr<IDiaSymbol> pglobal;
    if ( FAILED( psession->get_globalScope( &pglobal) ) )
    {
        Fatal( "get_globalScope" );
    }
    
  5. Use as interfaces IDiaEnum* para enumerar e examinar os símbolos ou outros elementos de informações de depuração.

    CComPtr<IDiaEnumTables> pTables;
    if ( FAILED( psession->getEnumTables( &pTables ) ) )
    {
        Fatal( "getEnumTables" );
    }
    CComPtr< IDiaTable > pTable;
    while ( SUCCEEDED( hr = pTables->Next( 1, &pTable, &celt ) ) && celt == 1 )
    {
        // Do something with each IDiaTable.
    }
    

Confira também