大端法小端法测试
测试程序
下面的程序段使用强制类型转换来访问和打印不同程序对象的字节表示.
首先将数据类型byte_pointer
定义为一个指向类型为unsinged char
的对象指针,这样一个字节指针引用一个字节序列,其中每个字节都被认为是一个非负整数.
#include <stdio.h>
typedef unsigned char *byte_pointer;
void show_bytes(byte_pointer start, size_t len)
{
size_t i;
for (i = 0; i < len; i++)
printf(" %.2x", start[i]);
printf("\n");
}
void show_int(int x)
{
show_bytes((byte_pointer) &x, sizeof(int));
}
void show_float(float x)
{
show_bytes((byte_pointer) &x, sizeof(x));
}
void show_pointer(void *x)
{
show_bytes((byte_pointer) &x, sizeof(void *));
}
void test_show_bytes(int val)
{
int ival = val;
float fval = (float) ival;
int *pval = &ival;
show_int(ival);
show_float(fval);
show_pointer(pval);
}
int main()
{
int testVal = 12345;
test_show_bytes(testVal);
return 0;
}
测试结果
对于上面的程序分别在64位的windows机器和64位的Linux机器上进行编译运行,其中参数的十六进制表示为
.
64位windows系统
![](https://img.haomeiwen.com/i16047645/094239f918398974.png)
64位Linux系统
![](https://img.haomeiwen.com/i16047645/99ca168c4d5374d6.png)
结果分析
- 对于
int
类型的数据,我们在windows和Linux64上都都得到了相同的结果,同时,最低有效字节最先输出,说明它们是小端法机器;
- 同样地,对于
float
类型的数据结果也是相同的; - 对于两种机器的指针值是完全不同的,说明不同的机器/操作系统使用不同的存储分配规则;
- 64位windows机器采用的是4字节地址,而Linux64使用的是8字节地址.
网友评论