深圳幻海软件技术有限公司 欢迎您!

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

2023-02-28

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

很多集成开发环境(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
#endif
  • 1.
  • 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)
#endif
  • 1.
  • 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: