确定主机字节序的程序

int main(int argc,char **argv) {
    union {
        short s;
        char c[sizeof(short)];
    } un;
    un.s = 0x0102;
    if (sizeof(short) == 2) {
        if (un.c[0] == 1 && un.c[1] == 2)
            printf("大端\n");
        else if (un.c[0] == 2 && un.c[1] == 1)
            printf("小端\n");
        else
            printf("unknown\n");
    }
    exit(0);
}

考虑16位的short整数,它由2个字节组成。内存中存储这两个字节有两种方法:一种格式将低序字节存储在起始地址,这称为小端字节序;另一种方法是将高序字节存储在起始地址,这称为大端字节序。

确定主机字节序的方法是:使用联合体定义一个short,和一个short字节大小的数组,这样通过赋值的short,能够通过数组的表示得到这个数值的地址存储方案。

时间: 2024-11-14 20:57:20

确定主机字节序的程序的相关文章

c# 主机和网络字节序的转换 关于网络字节序和主机字节序的转换

最近使用C#进行网络开发,需要处理ISO8583报文,由于其中有些域是数值型的,于是在传输的时候涉及到了字节序的转换. 字节顺序是指占内存多于一个字节类型的数据在内存中的存放顺序,通常有两种字节顺序,根据他们所处的位置我们分别称为主机节序和网络字节序. 通常我们认为网络字节序为标准顺序,封包的时候,将主机字节序转换为网络字节序,拆包的时候要将网络字节序转换为主机字节序. 原以为还要自己写函数,其实网络库已经提供了. 主机到网络:short/int/long IPAddress.HostToNet

第五篇:主机字节序与网络字节序的转换

前言 我们知道,数据在主机内的存放有两种模式,也就是说,主机字节序有两种:大端和小端( 这里假定读者已经清楚这个问题 ).但在网络通信中,要求通信数据( 通信数据这里指IP号和端口号 )的使用必须用网络字节序.什么又是网络字节序? 网络字节序可以理解为主机字节序的大端模式.如果你的主机字节序原本就是大端模式,那么你可以考虑不用将通信数据转换为网络字节序:但如果你的主机字节序是小端,那么通信数据必须被下面提及到的其中某个函数进行处理,转换成网络字节序后方可使用( 即存放进套接字地址结构变量 ).

网络字节序与主机字节序

最近在项目开发过程中,需要在采用JAVA作为语言的服务器与采用C++作为语言的服务器间进行通信,这就涉及到这两种语言间数据类型的转换以及网络字节序与主机字节序的区别.该文主要说说网络字节序和主机字节序的区别以及Little endian与Big endian的概念.其实编程的事就比较简单了   我也懒得写了,直接引用了我觉得写的挺好的两篇文章: 什么是Big Endian和Little Endian? 来源:http://blog.ednchina.com/qinyonglyz/194674/m

linux程序设计——主机字节序和网络字节序(第十五章)

15.2.10    主机字节序和网络字节序 当在基于intel处理器的linux机器上运行新版本的服务器和客户程序时,可以用netstat命令查看网络连接状况.它显示了客户/服务器连接正在等待关闭.连接将在一段超时间之后关闭,如下所示: 可以看到这条连接对应的服务器和客户的端口号.local address一栏显示的是服务器,而foreign address一栏显示的是远程客户(即使是在同一台机器上,它仍然是通过网络连接的).为了确保所有套接字都是不同的,这些客户端口一般都与服务器监听套接字不

网络字节序&主机字节序

什么是字节序?是指整数在内存中保存的顺序.       字节序有两种:       a.Little endinan 低位存储在内存的低地址,高位存储在内存的高地址:       b.Big endian 高位存储在内存的低地址,低位存储在内存的高地址: 举个简单的例子: DWORD dwCount = 0x01020304;这样的一个双字节变量在内存中如下分布0013FF70  04 03 02 01 (注:实验结果取之 XPSP3 VC6.0,说明我的机器是Little endinan序)

网络字节序与主机字节序 高低位

最近在项目开发过程中,需要在采用JAVA作为语言的服务器与采用C++作为语言的服务器间进行通信,这就涉及到这两种语言间数据类型的转换以及网络字节序与主机字节序的区别.该文主要说说网络字节序和主机字节序的区别以及Little endian与Big endian的概念.其实编程的事就比较简单了   我也懒得写了,直接引用了我觉得写的挺好的两篇文章: 什么是Big Endian和Little Endian? 来源:http://blog.ednchina.com/qinyonglyz/194674/m

网络字节序和主机字节序

1.大端.小端字节序 考虑一个16位整数,它由2个字节组成.内存中存储这两个字节有两种方法:一种是将低序字节存储在起始地址,这称为小端(little-endian)字节序:另一种方法是将高序字节存储在起始地址,这称为大端(big-endian)字节序.如下所示: 术语“大端”和“小端”表示多个字节值的哪一端(小端或大端)存储在该值的起始地址. 遗憾的是,这两种字节序之间没有标准可循,两种格式都有系统使用.比如,Inter x86.ARM核采用的是小端模式,Power PC.MIPS UNIX和H

主机字节序 与 网络字节序

一.字节顺序 是指占用内存多于一个字节类型的数据在内存中的存放顺序. java中一个int型数据占用4个字节,假如有一个16进制的int数,int value = 0x01020304 小端字节序(little endian):低字节数据存放在内存低地址 大端字节序(bigendian): 低字节数据存放在高地址处 主机字节序跟CPU有关的,IA架构(Intel.AMD)的CPU中是Little-Endian,而PowerPC .SPARC和Motorola处理器是Big-Endian. 网络字

Python网络编程——主机字节序和网络字节序之间的相互转换

If you ever need to write a low-level network application, it may be necessary to handle the low-level data transmission over the wire between two machines. This operation requires some sort of conversion of data from the native host operating system