地址绑定技术,在概念上,等效于联合体 union,例如:
unsigned char 型数组 Array[]拥有同样的起始地址。 它等效于下面的地
现对 unsigned long 型数据逐个字节的访问。考虑在上面的情形中,
下面的代码会有怎样的结果:
取决于所使用的计算机系统(单片机系统)采用哪种字节对齐方式。
我们知道 unsigned long 型变量 dNumber 由从低到高四个字节组成。
类似答案第一种: 4 个字节中高字节放在低位;低字节放在高位的字
节排列方式被称为“大端对齐”。类似第二种答案: 4 个字节中低字节
放在低位,高字节放在高位的字节排列方式被称为“小端对齐”。 不
同的计算机系统采用的字节对齐顺序不一定相同,编写代码时,如果
牵涉到对大数据类型的拆分,就尤其需要关心这个问题。这点一定要记牢哦。
//联合体实现地址绑定
union Example
{
unsigned long dNumber;
unsigned char Array[4];
}Data;
在这个联合体 Example 中, unsigned long 型变量 dNumebr 和unsigned char 型数组 Array[]拥有同样的起始地址。 它等效于下面的地
址绑定代码:
//与联合体等效的地址绑定
unsigned long dNumber = 0;
unsigned char *Array = (unsigned char *)(&dNumber);
于是,通过这两种方法,我们都能够利用数组(指针) Array 实现对 unsigned long 型数据逐个字节的访问。考虑在上面的情形中,
下面的代码会有怎样的结果:
//一个不能想当然的问题
dNumber = 0x01020304; //占用 4 个字节的 unsigned long
printf(“%d ”,Array[0]); //输出 dNumber 的第一个字节
printf(“%d ”,Array[1]); //输出 dNumber 的第二个字节
printf(“%d ”,Array[2]); //输出 dNumber 的第三个字节
printf(“%d ”,Array[3]); //输出 dNumber 的第四个字节
正像这类问题惯有的答案一样:两种答案都对,也都不对。这取决于所使用的计算机系统(单片机系统)采用哪种字节对齐方式。
我们知道 unsigned long 型变量 dNumber 由从低到高四个字节组成。
类似答案第一种: 4 个字节中高字节放在低位;低字节放在高位的字
节排列方式被称为“大端对齐”。类似第二种答案: 4 个字节中低字节
放在低位,高字节放在高位的字节排列方式被称为“小端对齐”。 不
同的计算机系统采用的字节对齐顺序不一定相同,编写代码时,如果
牵涉到对大数据类型的拆分,就尤其需要关心这个问题。这点一定要记牢哦。
<pre name="code" class="plain">