软件中 Debug 和 Release 到底有什么区别?

有很多软件集成开发环境(IDE),比如VS(VC)、IAR等,在创建工程时都会自动生成有Debug 和 Release两个版本。
有些小伙伴比较纳闷,Debug 和 Release两个版本到底有什么区别?
下面就来讲讲Debug 和 Release版本区别,及其相关的内容。

嵌入式专栏

1

关于Debug 和 Release版本
Debug,顾名思义,就是调试版本;
Release,即发布版本,或者说最终释放版本。
在一些项目中,会出现Debug 和 Release两个版本,比如:
IAR EWARM:
VS:
一些初学者可能会问,他们二者到底什么差异?
其实,Debug 和 Release两个版本其实主要就是工程配置不同。
我们这里拿IAR EWARM来说,主要是:Project -> Options 下面的配置选项不同:

嵌入式专栏

2

Debug 和 Release差异
Debug 和 Release两个版本,最根本的区别在于Debug版本多了一些与调试相关的配置内容。
1.生成调试信息
Debug版本通常会生成调试信息,而Release通常没有这些信息。
比如IAR EWRAM:
这里的“生成调试信息”其实包含了很多关于调试的信息,如果勾选会多出“.pbd”、 “.browse”、 “.linf”等与调试有关的信息。
补充①
“.pbd”、 “.browse”为浏览信息的文件,“.linf”为链接配置相关的文件。具体可以参看:IAR系列教程12_IAR文件类型描述
补充②
这个配置信息保存在“.ewp”(工程配置)文件下,包含了Debug 和 Release两个版本的配置信息:
<configuration> <name>Debug</name> ...配置 </configuration>
<configuration> <name>Release</name> ...配置</configuration>

你可以对比一下两个配置的差异,就知道二者的一些区别:

补充③
Keil MDK类似,也有类似的关于调试的配置:Projcet -> Options for Target:
2.预处理
Debug版本通常会有“DEBUG”相关的预处理(宏定义)
不知道大家经常用类似下面的调试宏定义没有:
#ifdef DEBUG  //Debug调试版本相关的配置strongerHuang#else  //Release发布版本相关的配置strongerHuang#endif
比如最常见的就是printf(打印信息),会通过“DEBUG”调试信息打开/关闭打印输出信息。
同理,这里与ASSERT断言类似,就是通过宏定义开关来打开/关闭,比如:
#ifdef  USE_FULL_ASSERT void assert_failed(uint8_t* file, uint32_t line);#else #define assert_param(expr) ((void)0)#endif
IAR 默认是在Release版本下预定义NDEBUG:
当然,这里全网可以自己根据自己实际情况进行定义。
3.其他不同
比如:在 Release 版本下增加一些axf转bin的命令
实际项目中,Debug 和 Release两个版本可能还有很多不同的配置,按理说“Options”下面的很多配置都可以不同。

嵌入式专栏

3

“版本”说明
这里是说的“版本”是指Debug 和 Release中的版本,并不是软件版本或其他什么版本。
Debug 和 Release都是自己配置的“版本”,只是有些IDE会自动生成这两个版本。
还是拿Keil 和 IAR 来说明,源码和工程结构都一样,只是配置不一样,简单来说,就是一个“克隆”版本。
1.IAR EWARM
Project -> Edit Configuartions:
2.Keil MDK
Project - Manage ->Project items:
相关的内容可以参看我的教程:

【专栏】IAR系列教程

【专栏】Keil系列教程

------------ END ------------
(0)

相关推荐