Release版本错误解决方案及调试
2011-07-26 13:59
232 查看
关于release版本调试信息不正确(指跟踪到的变量的值不正确)的问题:
先写好了debug版本,并进行了测试,发现功能都正常。然后想build一个release版本,将出现的编译和链接错误都搞定后,运行测试功能,发现功能不正确。这种问题很头痛,只好去debug,一步一步跟踪发现变量的值都不正确,即使初始化了也一样,例如有这样的定义int a=1; 但发现a的值根本不是1.最后把编译环境中的Optimization由Maximize Speed (/O2)改为Disabled (/Od),这样就OK了。
原因总结:主要是因为Release版本编译环境默认开启了优化(Optimization默认为Maximize Speed (/O2) ),只要设置成不进行优化(将Optimization由Maximize Speed (/O2)改为Disabled (/Od))就可以获取到正确的调试信息。至于Debug Information Format一项为Program Database for Edit & Continue (/ZI)或者 Program Database (/Zi)都可以进行Release版本的调试。
不过不是很明白,Release优化居然会优化成这样?连像int a=1;这样的初始化都不正确了,a的值变的莫名其妙!真不知道编译器是怎么优化的?
关于debug版本转换成release版本可能出现的错误及其解决方案:
1.转换后有编译错误:这一类比较简单,一般可以根据错误提示信息解决,编译错误需要修改程序代码。
2.转换后有链接错误:也比较简单,一般是需要链接某些库文件。
3.运行时错误或运行正常但程序某些功能失效:这一般是因为编译器优化引起的,一般可以通过改变编译环境中的某些优化编译选项来解决,并不需要修改程序代码。
得到的经验教训:
一、在编程过程中就要时常注意测试Release版本,不要到整个工程结束后才测试release版本,这时候代码很多,调试更加困难。
二、在开始Release版本的编写或测试前,先根据下面设置好编译环境:
1.C/C++ —> General —> Debug Information Format: Program Database for Edit & Continue (/ZI)
2.C/C++ —> Optimization —> Optimization: Disabled(/Od)
3.C/C++ —> Code Generation —>Runtime Library: Multi-threaded DLL(/MD)
4.Linker —> Debugging —> Generate Debug Info: Yes(/DEBUG)
5.General —> Use of MFC —> Use MFC in a Static Library
6.General —> Whole Program Optimization: No
7.C/C++ —> Precompiled Header —>......
8.Linker —> Optimization —>......
先写好了debug版本,并进行了测试,发现功能都正常。然后想build一个release版本,将出现的编译和链接错误都搞定后,运行测试功能,发现功能不正确。这种问题很头痛,只好去debug,一步一步跟踪发现变量的值都不正确,即使初始化了也一样,例如有这样的定义int a=1; 但发现a的值根本不是1.最后把编译环境中的Optimization由Maximize Speed (/O2)改为Disabled (/Od),这样就OK了。
原因总结:主要是因为Release版本编译环境默认开启了优化(Optimization默认为Maximize Speed (/O2) ),只要设置成不进行优化(将Optimization由Maximize Speed (/O2)改为Disabled (/Od))就可以获取到正确的调试信息。至于Debug Information Format一项为Program Database for Edit & Continue (/ZI)或者 Program Database (/Zi)都可以进行Release版本的调试。
不过不是很明白,Release优化居然会优化成这样?连像int a=1;这样的初始化都不正确了,a的值变的莫名其妙!真不知道编译器是怎么优化的?
关于debug版本转换成release版本可能出现的错误及其解决方案:
1.转换后有编译错误:这一类比较简单,一般可以根据错误提示信息解决,编译错误需要修改程序代码。
2.转换后有链接错误:也比较简单,一般是需要链接某些库文件。
3.运行时错误或运行正常但程序某些功能失效:这一般是因为编译器优化引起的,一般可以通过改变编译环境中的某些优化编译选项来解决,并不需要修改程序代码。
得到的经验教训:
一、在编程过程中就要时常注意测试Release版本,不要到整个工程结束后才测试release版本,这时候代码很多,调试更加困难。
二、在开始Release版本的编写或测试前,先根据下面设置好编译环境:
1.C/C++ —> General —> Debug Information Format: Program Database for Edit & Continue (/ZI)
2.C/C++ —> Optimization —> Optimization: Disabled(/Od)
3.C/C++ —> Code Generation —>Runtime Library: Multi-threaded DLL(/MD)
4.Linker —> Debugging —> Generate Debug Info: Yes(/DEBUG)
5.General —> Use of MFC —> Use MFC in a Static Library
6.General —> Whole Program Optimization: No
7.C/C++ —> Precompiled Header —>......
8.Linker —> Optimization —>......
相关文章推荐
- Release版本错误解决方案及调试
- Release版本错误解决方案及调试
- Release 版本调试错误--VC
- Release版本的Lnk2001错误的一个另类问题解决方案
- VS2013设置release版本可调试
- Release版本下显示调试信息
- Unsupported major.minor version (jdk版本错误)解决方案 办法
- VS调试错误:“没有可用于当前位置的源代码”的解决方案
- 调试JavaScript 错误的解决方案
- VC6.0 Release版本中调试设置
- 如何调试程序的 Release 版本
- 程序Debuge版本编译通过,Release版本出现链接错误,解决办法
- 实现Visual Studio Release版本工程调试的方法
- 使用宏定义打开/关闭调试输出(debug版本与release版本互相切换)
- VS2008 如何将Release版本设置可以调试的DEBUG版本
- Release版本的调试设置
- vs2010打不开vs2017的.sln文件,出现错误提示 “选择的文件是解决方案文件 但是用此应用程序的较新版本创建的,无法打开”
- DEBUG和RELEASE 版本差异及调试相关问题(VS - VC++)
- vmware安装ubuntu13版本的vm tools时 遇到的错误,解决方案
- VC++2005、VC2008中Release版本设置为可调试的设置方法