软件项目中 Debug 和 Release 版本的差异

作者阿里云代理 文章分类 分类:新闻快递 阅读次数 已被围观 467

很多集成开发环境(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:

编辑搜图


本公司销售:阿里云、腾讯云、百度云、天翼云、金山大米云、金山企业云盘!可签订合同,开具发票。

我有话说: