linux网络编程一:主机字节序与网络字节序的的判断
2014-03-30 13:21
281 查看
最近在看《linux高性能服务器编程》,在此做个日记,以激励自己,同时分享于有需要的朋友。
现代CPU的累加器一次能装载至少4字节(32位),即一个整数。那么这4字节在内存中排列的顺序将影响它被累加器装载成的整数值,这就是字节序问题。
字节序分大端字节序(big endian)和小端字节序(little endian),大端字字节序是指一个整数的高位字节(23~31bit)存储在内存的低地址外,低位字节(0~7bit)存储在内存的高地址处。 小端字节序则是指整数的高位字节存储在内存的高地址处,而低位字节存储在内存的低地址处。
现代PC大多采用小端字节序,因此小端字节序又被称为主机字节序。
当格化数的数据在两台使用不同字节序的主机之间直接传递时,接收端必然错误解释之。解决方法是:发送端总是把要发送的数据转化成大端字节序数据后再发送,而接收端知道对方传送过来的数据总是采用大端字节序,所以接收端可以根据自身采用的字节序决定是否对接收到的数据时行转换。
因此,大端字节序也称为网络字节序,它给所有接收数据的主机提供了一个正确解释收到的格式化数据的保证。
现代CPU的累加器一次能装载至少4字节(32位),即一个整数。那么这4字节在内存中排列的顺序将影响它被累加器装载成的整数值,这就是字节序问题。
字节序分大端字节序(big endian)和小端字节序(little endian),大端字字节序是指一个整数的高位字节(23~31bit)存储在内存的低地址外,低位字节(0~7bit)存储在内存的高地址处。 小端字节序则是指整数的高位字节存储在内存的高地址处,而低位字节存储在内存的低地址处。
现代PC大多采用小端字节序,因此小端字节序又被称为主机字节序。
当格化数的数据在两台使用不同字节序的主机之间直接传递时,接收端必然错误解释之。解决方法是:发送端总是把要发送的数据转化成大端字节序数据后再发送,而接收端知道对方传送过来的数据总是采用大端字节序,所以接收端可以根据自身采用的字节序决定是否对接收到的数据时行转换。
因此,大端字节序也称为网络字节序,它给所有接收数据的主机提供了一个正确解释收到的格式化数据的保证。
//用于检查机器字节序的代码: #include <stdio.h> void byteorder() { union { short value; char union_bytes[ sizeof( short ) ]; } test; test.value = 0x0102; if ( ( test.union_bytes[ 0 ] == 1 ) && ( test.union_bytes[ 1 ] == 2 ) ) { printf( "big endian\n" ); } else if ( ( test.union_bytes[ 0 ] == 2 ) && ( test.union_bytes[ 1 ] == 1 ) ) { printf( "little endian\n" ); } else { printf( "unknown...\n" ); } } int main(int argc, char **argv) { byteorder(); return 0; }
相关文章推荐
- Linux 网络编程——网络字节序、地址转换
- Linux 网络编程——网络字节序、地址转换
- Linux 网络编程——网络字节序、地址转换
- Linux网络编程--服务端判断客户端断开的经验方法
- 网络编程中的网络字节序与主机字节序
- linux网络编程之网络字节序、主机字节序、大端、小端
- 我的网络编程学习之路——主机字节序和网络字节序
- 【linux网络编程】网络字节序、地址转换
- Linux 网络编程详解一(IP套接字结构体、网络字节序,地址转换函数)
- linux网络编程学习之一网络字节序
- 网络编程中的主机字节序与网络字节序
- Linux网络编程--服务端判断客户端断开的经验方法
- 【LINUX网络编程】Makefile文件
- Linux+javaEE学习之文件的压缩+解压缩+java网络编程
- Linux网络编程入门必备函数说明
- linux UDP网络编程
- linux网络编程之简单的回射服务器
- [Linux网络编程]Linux网络套接字操作函数--使用bind函数绑定套接字
- LINUX网络编程-完整的读写函数
- Linux网络编程