keil编译生成hex文件大小与单片机内的flash空间大小有什么关系啊

keil编译生成hex文件大小与单片机内的flash空间大小有什么关系啊。。我用的单片机有64K的flash为什么我编译生成的77K的hex文件也能用烧录器烧进去啊 。。谢谢高人指点
我用的是at89C51ed2

1. keil编译生成hex文件大小与单片机内的flash空间大小 没有关系!

2. HEX 文件的大小,不是最终的代码大小, 一般实际要更小一些. 如果有兴趣研究,可以下载一下叫做 hex2bin 的小程序,可以把hex转换为bin的

Intel hex 文件格式解密

Intel hex 文件常用来保存单片机或其他处理器的目标程序代码。它保存物理程序存储区中的目标代码映象。一般的编程器都支持这种格式。
Intel hex 文件全部由可打印的ASCII字符组成(可以用记事本打开),如下例所示:

:2000000012014c75a800e4f508f509780a7a78e4f608dafcd283fcfded240af9a7050dbd81
:2000200000010ced2488ec34ff50edc283e4fcfded240af9e76d7013ed33e43c700d0dbd2a
:2000400000010ced2488ec34ff50e50509e50970020508e50924a8e50834fd50aee4f50874

Intel hex 由一条或多条记录组成,每条记录都由一个冒号“:”打头,其格式如下:

:CCAAAARR...ZZ      

其中:

CC    本条记录中的数据字节数

AAAA   本条记录中的数据在存储区中的起始地址

RR    记录类型:     
00 数据记录 (data record)     
01 结束记录 (end record)     
02 段记录 (paragraph record)     
03 转移地址记录 (transfer address record)

...   数据域

ZZ   数据域校验和

Intel hex文件记录中的数字都是16进制格式,两个16进制数字代表一个字节。CC域是数据域中的实际字节数,地址、记录类型和校验和域没有计算在内。校验和是取记录中从数据字节计数域(CC)到数据域(...)最后一个字节的所有字节总和的2的补码。
温馨提示:内容为网友见解,仅供参考
第1个回答  2008-09-02
Hex文件是一个16进制文件,可以用记事本打开后看到其ASCII码,这个是高层文件的大小。
而我们平时说的64K程序的单片机是值有64KB二进制储存空间,Keil生成Hex文件的的具体文件结构有下面的朋友“_bingri”回答了,由此得出真正的所需要的二进制文件要比Hex小。
至于Hex的大小,同样一个工程文件,选择不同的编译参数和命令行,就能得到同样功能(即由16进制转到2进制的机器码大小不变),但Hex文件大小不同的文件(选择不同的编译参数和命令行)。

另外,要值得注意的是,根据我的认识,我还有纠正下面的一位朋友“_bingri”的一个错误:keil编译生成hex文件大小与单片机内的flash空间大小 没有关系!
这个是错误的:这个是有关系的,并且如果程序的容量比单片机的Rom的容量大很多时,多出单片机最大Rom地址的代码将无法写入芯片中(而现在的上层编程器相应的烧写软件都可能基本上在这之前就对HEX转成的2进制文件大小进行判断了,如果超出实际大小,就不能烧写芯片了)
第2个回答  2008-08-21
HEX文件的77K,是指77K BYTE,还是77K bit?
如是BYTE,你这77KB,是不是通过点右键属性里看到的,还是把鼠标放在文件上显示出来的。这两种查看的方法会有点区别。如真的是77KBYTE,烧录的时候好像会出错。我以前烧录过8MB,只超过几十KB,就出错了。
如是bit,就不用说了,绝对可以的。
第3个回答  2008-08-20
keil编译生成hex文件不全是要烧录到单片机内.

实际大小可以在烧录软件的编辑中看到.
第4个回答  2008-08-21
hex生成二进制代码(0,1)才是真正的大小,在烧录软件的编辑筐中看到

keil编译生成hex文件大小与单片机内的flash空间大小有什么关系啊
1. keil编译生成hex文件大小与单片机内的flash空间大小 没有关系!2. HEX 文件的大小,不是最终的代码大小, 一般实际要更小一些. 如果有兴趣研究,可以下载一下叫做 hex2bin 的小程序,可以把hex转换为bin的 Intel hex 文件格式解密 Intel hex 文件常用来保存单片机或其他处理器的目标程序代码。它保存...

怎样知道hex文件烧到单片机中占多大程序存储器空间
大约3~4K,单片机的程序都是 .BIN格式的文件,其大小大约为 .HEX文件的三分之一。你可以将 .HEX文件转变为 .BIN文件再看它的大小,一定占不了8KB的空间。

flash仿真器的hex文件怎么对比
flash仿真器的hex文件对比的方法:首先用notepad打开hex文件的代码,然后用观察代码的结构找出有限数据。

keil5生成hex文件一行为什么是16字节
keil5生成hex文件一行是16字节原因:生成的hex文件超出了单片机的存储单元的大校。这个是有关系的,并且如果程序的容量比单片机的Rom的容量大很多时,多出单片机最大Rom地址的代码将无法写入芯片中,而现在的上层编程器相应的烧写软件都可能基本上在这之前就对HEX转成的2进制文件大小进行判断了,如果超出实...

单片机程序大小是看生成的HEX文件的大小还是看KEIL编译结束后显示的CO...
无论是HEX的大小,还是编译后CODE的大小,都不是烧入到MCU中代码的“真实”容量。因为这里涉及到数据存放格式相关问题,具体我就不说了。一般来说,烧入到MCU硬件中去的程序大小,会比你keil编译后的CODE的大小稍微小一些,但差距不会很大。所以在一般使用中,可以把编译后CODE的大小来作为实际程序容量...

51单片机程序空间大小
而KeilC编译的HEX代码文件并不是纯二进制数,是以ASCII码格式存放的文件,而且其中还有一些编译信息,如地址、校验和等。所以,不能看HEX文件的大小来确定下载到单片机内的真正的程序空间大小,也就是说HEX文件的大小并不是真正下载的单片机的程序大小。而下载到单片机的代码空间大小要看Keilc编译时给出的...

为什么用keil 4生成的HEX文件会比较大?
代码就增加到151字节,增加的是keil调用一个赋初值的功能,类似调用了一个函数,再增加赋初值的变量定义,就不会增加那么多了,一般字符型会增加3字节。如果你使用了超出64K的程序,应该还有一些东西,没用过,你应该没有使用这个功能。 至于你的有2.5K,我就不知道还有什么东西了。

...大量用延时函数使CPU空转,是不是很占用单片机空间?
程序存在单片机flash中的空间大小要看keil编译程序过后最下面的output window中的code大小。尽量不要大量使用延时函数,最好就不要使用,非要用的话也不要超过10ms。因为用中断的话,只要中断源触发进入中断,正好卡在delay函数这个地方,那中断再回来延时就不准确了。看HEX文件大小的方法是不正确的。

为什么用keil生成的hex文件总是69字节?
可能是你生成hex文件超出了单片机的存储单元的大小

单片机程序大小是看生成的HEX文件的大小还是看KEIL编译结束后显示的CO...
是看CODE的大小,而且这个大小是十进制的,也是烧进单片机内占用内存多少的数据。

相似回答