从inet_pton()看大小端字节序
#include<stdio.h> #include<netinet/in.h> #include<stdlib.h> #include<string.h> int main(){ char * str=(char *)malloc(20); char * p="0.0.0.1"; struct sockaddr_in servaddr; bzero(&servaddr,sizeof(servaddr)); inet_pton(AF_INET,p,&servaddr.sin_addr); printf("0.0.0.1 converted to decimal %u\n",servaddr.sin_addr); sprintf(str,"%u",servaddr.sin_addr); printf("decimal converted to string %s\n",str); int *pnt=(int *)str; printf("string converted to decimal array %u\n",*pnt); free(str); return; }
运行结果如下
0.0.0.1 converted to decimal 16777216 decimal converted to string 16777216 string converted to decimal array 926365233
0.0.0.1 的二进制表示是00000000 00000000 00000000 00000001
16777216 的二进制表示是00000001 00000000 00000000 00000000
由此可见,0.0.0.1是按 big endian 字节序存储的。
有一点需要明确,无论big/little endian, int或其他任何>=1B的变量的读取必然是由高到低读取)。另外,堆栈的增长是自高向低地址方向增长的,所以,0.0.0.1只有按如下方式存储才会被解释为16777216。
----stack高地址---00000001---00000000---00000000---00000000---stack低地址-----
同理,926365233 的解释:
'1677'占4个byte,正好被解释为一个整数,而 926365233(decimal)= 00110111 00110111 00110110 00110001(binary) ='7761'(ascii)
显然,上面也是一个大端字节序。
本程序算是一箭双雕解释了大小端字节序。另外,从apue上借鉴了一下 union方法判断字节序的方法,贴在下面,其实和上文异曲同工,
#include<stdio.h> #include<stdlib.h> int checkCPU( ) { { union w { int a; char b; } c; c.a = 1; return(c.b ==1); } } int main(){ if(checkCPU()==1){ printf("big end"); } return; }