Windows应用程序调试必备的--符号文件(Symbols)

原创 2003年10月30日 13:45:00

Windows Symbol Files

 

1.什么是Symbol File?     

              Symbol files hold a variety of data which are not actually needed when running the binaries(Dll,EXE...), but which could be very useful in the debugging process(It's a good partner for VC6++ and WinDbg).
             通俗的说,Symbol File是包含了相关二进制文件(EXE,DLL)调试信息的一种文件,它以.pdb为扩展名,比如WinXP下有一个
GDI32.dll,那么微软在编译该DLL的时候会产生一个GDI32.pdb文件,程序员有了这个PDB文件愿意的话就可以用它来调试,跟踪到GDI32.dll的内部去!
             该文件和二进制文件的编译版本密切相关,比如你修改了DLL的输出函数等,再编译该DLL那么原先的PDB文件就过时了,不能再胜任调试的重担了,这时候你需要的是修改后编译产生的PDB文件.
            
大家在用VC6编译的时候会发现PDB文件会存在于Debug/Release目录下(关于如何产生Release版本的PDB请参看4.如何在VC6++中编译产生Release版本的二进制文件的PDB文件?).

Typically, symbol files might contain:
    1.
全局变量
(Global variables)
    2.
局部变量
(Local variables)
    3.
函数名和它们的入口地址
(Function names and the addresses of their entry points)
    4.FPO data(frame pointer omission),frame pointer
是一种用来在调用堆栈(Call stack)中找到下一 个将要被调用的函数的数据结构源代码的行序号(Source-line numbers)

2.如何得到Symbol Files?

       要安装Symbol Files请先确定你的OS版本再到微软的网站上去下载相应的Symbol Files安装,安装没有什么特殊的要求,只需要随便安装到一个目录,然后在Windows的环境变量中中设定这个Path(也可以在VC6,WinDbg中设置,这样的话只有Vc6或者是WinDbg自己能看到了…)然后WinDbg,Ntsd,

DrWatson之类的调试软件就可以找到了.
   安装Symbol Files就一个原则,请大家注意:

    "If you plan to install symbols manually, it is crucial that you remember this basic rule: the symbol files on the host computer are required to match the version of Windows installed on the target computer"

   host computer     The host computer is the machine that runs the debugging session. In a typical two-system debugging  session, the host can be any computer which can be connected to the target computer

   target computer  The target computer is the machine that has experienced the failure of a software component, system service, an application, or of the operating system. This is the computer that needs to be debugged and is the focus of the debugging session. This can be a computer located within a few feet of the computer on which you run the debugging session, or it can be in a completely different location. Sometimes referred to as the debuggee

3.如何在VC6中集成Symbol Files??   

     1.Open your workspace in VC6++;
     2.Open the Options dialog box (Tools->Options);
     3.Click the Directoties tab;
     4.Click Executable files from the Show directories for drop-down list;
     5.Add the path of symbol-files  to path-list;
     6.Click OK to finish.

4.如何在VC6++中编译产生Release版本的二进制文件的PDB文件?

 

 这是Microsoft的方法,实战中为了使得我们的代码被别人Copy到其他地方也可以编译通过我一般用#pragma预编译开关来帮助我产生我需要的文件:

 

 

5.Free Build(retail build) and Checked Build(debug build)

   Two different builds of each NT-based operating system exist:
   The free build (or retail build) of Windows is the end-user version of the operating system. The system and drivers are built with full optimization, debugging asserts are disabled, and debugging information is stripped from the binaries. A free system and driver are smaller and faster, and it uses less memory.
The checked build (or debug build) of Windows serves as a testing and debugging aid in the developing of the operating system and kernel-mode drivers. The checked build contains extra error checking, argument verification, and debugging information that is not available in the free build. A checked system or driver can help isolate and track down driver problems that can cause unpredictable behavior, result in memory leaks, or result in improper device configuration.
    Although the checked build provides extra protection, it consumes more memory and disk space than the free build. System and driver performance is slower for the following reasons:
    The executables contain symbolic debugging information.
    Additional code paths are executed due to parameter checking and output of diagnostic messages for debugging purposes.

 

6.如何更新Symbols

          如果大家用上了WinDbg会发现符号文件(PDB)有多么的重要,可是这些文件都是和本地的OS相关的比如说你的WinXP打了SP补丁的话可能原来的符号文件就会出现不匹配的想象怎么办?网上更新!请在你们的WinDbg的Symbols Path里面输入下面一行:

        SRV*D:/Symbols/websymbols*http://msdl.microsoft.com/download/symbols

       (红色部分写上你们想保存的本地路径)

如果你不是通过代理上网,那么在你用WinDbg打开一个被调试程序后,输入symchk回车,windbg就会自动的连到微软的网站根据你的机器的情况更新新的PDB文件并保存在上面红色部分的本地路径里面,这样你就可以确保你的符号文件版本和你机器上的文件的版本一致(我指的是系统文件:DLL,SYS...).

 

如果你是通过代理上网那么你需要配置一下:

注意:http://home.lenovo/proxy.pac是我假设的代理配置脚本地址;10.99.20.26:8080是我假设的代理服务器地址和端口,实战中请根据你自己的情况设置.

1.配置好IE;


2.设置一个环境变量;
  

该环境变量为:_NT_SYMBOL_PATH;像我这样填写就可以了


3.告诉WinDbg:以后可以去微软网站下载PDB文件了 

有任何问题欢迎邮件交流:yangminga@lenovo.comperdubug@hotmail.com

 

如何安装并使用Windows Symbol

1. 下载符合你所运行的Windows版本的Windows Symbol Package:http://www.microsoft.com/whdc/devtools/debugging/symbol...
  • wallaceli1981
  • wallaceli1981
  • 2011年04月28日 15:11
  • 5599

安装与配置windbg的symbol(符号)

本篇是新手自己写的一点心得.建议新手看看.同时希望前辈多多指教. 写这篇的动机:在网上找了一上午的windbg配置符号教程.楞是没找到详细的,都讲的太 模糊而且互相抄袭.不适合新手看.终于靠自己的...
  • whatday
  • whatday
  • 2012年02月24日 12:04
  • 52607

让Visual Studio载入Symbol(pdb)文件

让Visual Studio载入Symbol(pdb)文件 在VC编译工程的编译连接阶段,会产生Symbol文件,也就是常说的 pdb 文件。pdb 的全称为 program database,在 M...
  • xt_xiaotian
  • xt_xiaotian
  • 2010年03月16日 09:26
  • 20437

windows符号文件的设置

1. 在进行Windows Driver开发调试中,内核符号表是个问题。由于网络不稳定,利用windbg下载不了,在WDK的documentation中查找到下载然后本地运用的地址,URL:http:...
  • xsophiax
  • xsophiax
  • 2015年04月04日 17:51
  • 600

Window xp sp3 调试符号(symbols)完整包

  • 2013年05月29日 08:57
  • 209.05MB
  • 下载

图解 windbg设置符号文件路径和使用入门

下载下来的windbg如下,有三个版本,x86,x64,汉化; 进入如下网址,选择合适版本的符号文件; 查看本机系统版本;选择Win7 Servic...
  • bcbobo21cn
  • bcbobo21cn
  • 2016年06月15日 16:27
  • 2003

使用OD加载微软符号库

Windbg可以加载微软符号库,如果本地没有符号,可以自动去微软网站上下载对应的PDB文件辅助调试分析。 PS:WingDbg下的符号加载,SRV*c:/windows/symbols*http:/...
  • SR0ad
  • SR0ad
  • 2012年12月03日 20:45
  • 3946

构建symbols 符号文件服务器 相关文章

转载http://libo.deng.blog.163.com/blog/static/4015742220086945543790/上的文章 建立 Symbols服务器建立Symbols Serve...
  • hbu_wzq
  • hbu_wzq
  • 2009年07月15日 21:56
  • 509

微软符号服务器下载符号总结

 微软符号服务器地址http://msdl.microsoft.com/download/symbols, 但是你手动在浏览器里面输入是访问不到的,他只提供给调试程序进行下载 1、方法1:  ...
  • xiliang_pan
  • xiliang_pan
  • 2015年12月16日 13:28
  • 1582

iOS开发者提交应用接收到邮件Too many symbol files - These symbols have no corresponding slice in any binary

转自:http://stackoverflow.com/questions/25755240/too-many-symbol-files-after-successfully-submitting-m...
  • zhanglizhi111
  • zhanglizhi111
  • 2017年03月30日 16:58
  • 1433
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Windows应用程序调试必备的--符号文件(Symbols)
举报原因:
原因补充:

(最多只允许输入30个字)