既生Bin 何生Hex ?-bin是什么文件

我们在编译生成固件的时候,有时候生成Hex文件有时候生成Bin文件,这两种文件有什么关系呢,它们存在的价值又是什么呢?

既生Bin 何生Hex ?

Hex文件和Bin文件是什么

Hex文件是以ASCII文本形式保存编译后的二进制文件信息。Hex文件使用ASCII文本的形式保存Bin文件的内容和Bin文件的一些配置信息。Hex文件可以由下载器(比如jlink)烧写到MCU的ROM中。

Bin文件是MCU固件烧写的最终形式,也就是说MCU的ROM中烧写的内容完全就是Bin文件的内容。

Hex文件和Bin文件的关系

Hex文件可以说是MCU固件的中间形式,由下载器的软件根据Hex文件生成Bin文件再烧写到MCU的ROM中。既然Bin文件是最终我们想要的,那么Hex文件有什么存在价值?我们为什么不直接生成Bin文件,却要生成Hex文件呢?

这就要从Hex文件的内容格式说起来了。

Hex的内容格式

从上面我们知道Hex文件不只是保存Bin文件的内容,还有一些配置信息。我们以一个例子大概说下Hex文件的结构,见下图:

既生Bin 何生Hex ?

上图的Hex文件总共6行的内容。每行都是以':'开始,之后是地址域、数据类型、数据域和校验和。

既生Bin 何生Hex ?

最后一行的数据类型是0x01,代表文件结束了。

既生Bin 何生Hex ?

Hex文件和Bin文件的存在价值

从上面的介绍中,我们发现Hex文件中每行的内容,就像我们发送串口数据的数据帧,并且最后一行还指示出文件结束了。我们得出hex文件的两个优点:

1. 使用ASCII文本保存固件信息,方便查看一些固件内容;

2. 通过文件每行的校验和与最后一行的文件结束标志,在文件的传输与保存过程中能够发现固件是否完整。

既生Bin 何生Hex ?

Hex文件有更好的可读性,最重要的是hex文件能够保证固件在保存与传输时的完整性。因此hex文件更适用于保存与传输。

而Bin文件是纯二进制文件,内部只包含程序编译后的机器码和变量数据。当文件损坏时,我们也无法知道文件已损坏。不过Bin文件作为固件的最终形式,在使用串口下载程序或者远程升级时,是不可替代的。

推荐阅读