软件项目中 Debug 和 Release 版本的差异
很多集成开发环境(IDE),比如VS(VC)、IAR等,在创建工程时都会自动生成有Debug 和 Release两个版本。
有些小伙伴比较纳闷,Debug 和 Release两个版本到底有什么区别?
下面就来讲讲Debug 和 Release版本区别,及其相关的内容。
编辑搜图
关于Debug 和 Release版本
Debug,顾名思义,就是调试版本;
Release,即发布版本,或者说最终释放版本。
在一些项目中,会出现Debug 和 Release两个版本,比如:
IAR EWARM:
编辑搜图
VS:
一些初学者可能会问,他们二者到底什么差异?
其实,Debug 和 Release两个版本其实主要就是工程配置不同。
我们这里拿IAR EWARM来说,主要是:Project -> Options 下面的配置选项不同:
编辑搜图
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>1.2.3.4.5.6.7.8.9.
你可以对比一下两个配置的差异,就知道二者的一些区别:
补充③:Keil MDK类似,也有类似的关于调试的配置:Projcet -> Options for Target:
编辑搜图
2. 预处理
Debug版本通常会有“DEBUG”相关的预处理(宏定义)
不知道大家经常用类似下面的调试宏定义没有:
#ifdef DEBUG //Debug调试版本相关的配置strongerHuang#else //Release发布版本相关的配置strongerHuang#endif1.2.3.4.5.
比如最常见的就是printf(打印信息),会通过“DEBUG”调试信息打开/关闭打印输出信息。
同理,这里与ASSERT断言类似,就是通过宏定义开关来打开/关闭,比如:
#ifdef USE_FULL_ASSERT void assert_failed(uint8_t* file, uint32_t line);#else #define assert_param(expr) ((void)0)#endif1.2.3.4.5.
IAR 默认是在Release版本下预定义NDEBUG:
编辑搜图
当然,这里全网可以自己根据自己实际情况进行定义。
3. 其他不同
比如:在 Release 版本下增加一些axf转bin的命令:
编辑搜图
实际项目中,Debug 和 Release两个版本可能还有很多不同的配置,按理说“Options”下面的很多配置都可以不同。
“版本”说明
这里是说的“版本”是指Debug 和 Release中的版本,并不是软件版本或其他什么版本。
Debug 和 Release都是自己配置的“版本”,只是有些IDE会自动生成这两个版本。
还是拿Keil 和 IAR 来说明,源码和工程结构都一样,只是配置不一样,简单来说,就是一个“克隆”版本。
1. IAR EWARM
Project -> Edit Configuartions:
编辑搜图
2. Keil MDK
Project - Manage ->Project items:
编辑搜图
我有话说: