大端法与小端法
计算机存储数据都是从低地址到高地址,如0x100到0x103存储,而大端法和小端法的区别就是存储数据时是取数据的低位存放在高地址还是高位存放在高地址。
大端法:数据低位存放高地址。
小端法:数据高位存放高地址。
举个例子,现有一个int a,地址为0x12 34 56 78,从左向右是高位到低位
对大端法而言,存放顺序是,12 34 56 78;对小端法而言,存放顺序是78 56 34 12;
union:
1.多个成员共用一块内存,编译时会选取成员中长度最长的来声明。如下
#include<stdio.h>
#include<stdlib.h>
union sizeTest {
int a[10];
double b;
};
int main() {
union sizeTest unionA;
printf("the sizeof of unionA is %d\n", sizeof(unionA));
system("pause");
return 0;
}
按照union中最大内存40个字节来声明。
2.union的首地址是固定的,变量共用一块内存,所以出现下面的情况:
#include<stdio.h>
#include<stdlib.h>
union var {
char c[4];
int i;
};
int main() {
union var data;
data.c[0] = 0x04;
data.c[1] = 0x03;
data.c[2] = 0x02;
data.c[3] = 0x11;
printf("%x\n", data.i);
system("pause");
return 0;
}
因为我的电脑是小端法,char c[4]的存储地址是从低位到高位,但是作为一个整体int i,数据高位放高地址,即0x11020304。