windows文件和linux文件大小转换

windows文件和linux文件大小转换,第1张

可以使用Linux的du命令来转换Windows文件的大小。du命令可以把Windows文件的大小转换为Linux文件的大小,以便更好地管理Linux文件系统。可以使用Linux的du命令来转换Windows文件的大小。du命令可以把Windows文件的大小转换为Linux文件的大小,以便更好地管理Linux文件系统。

不同机器内部对变量的字节存储顺序不同,有的采用大端模式(big-endian),有的采用小端模式(little-endian)。大端模式是指高字节数据存放在低地址处,低字节数据放在高地址处。小端模式是指低字节数据存放在低地址处,高字节数据放在高地址处。在网络上传输数据时,由于数据传输的两端可能对应不同的硬件平台,采用的存储字节顺序也可能不一致,因此 TCP/IP 协议规定了在网络上必须采用网络字节顺序(也就是大端模式) 。通过对大小端的存储原理分析可发现,对于 char 型数据,由于其只占一个字节,所以不存在这个问题,这也是一般情况下把数据缓冲区定义成 char 类型 的原因之一。对于 IP 地址、端口号等非 char 型数据,必须在数据发送到网络上之前将其转换成大端模式,在接收到数据之后再将其转换成符合接收端主机的存储模式。Linux 系统为大小端模式的转换提供了 4 个函数,输入 man byteorder 命令可得函数原型: <EM><STRONG><SPAN>#include <arpa/inet.h>uint32_t htonl()(uint32_t hostlong)uint16_t htons(uint16_t hostshort)uint32_t ntohl(uint32_t netlong)uint16_t ntohs(uint16_t netshort)</SPAN></STRONG></EM>htonl 表示 host to network long ,用于将主机 unsigned int 型数据转换成网络字节顺序;htons 表示 host to network short ,用于将主机 unsigned short 型数据转换成网络字节顺序;ntohl、ntohs 的功能分别与 htonl、htons 相反。通常使用的有两种数据类型:短型(两个字节)和长型(四个字节)。下面介绍的这些转换函数对于这两类的无符号整型变量都可以正确的转换。如果你想将一个短型数据从主机字节顺序转换到网络字节顺序的话,有这样一个函数htnos:它是以"h”开头的,代表“主机”;紧跟着它的是"to",代表“转换到”;然后是"n",代表“网络”;最后是"s",代表“短型数据”。你可以使用"n", "h", "to", "s", "l"的任意组合。当然,你要在可能的情况下进行组合。比如,系统是没有stolh()函数的(Short to Long Host ?)。下面给出套接字字节转换程序的列表:hotns()——"Host to NetWork Short",主机字节顺序转换为网络字节顺序(对无符号短型进行 *** 作 4bytes)htonl()——"Host to NetWork Long",主机字节顺序转换为网络字节顺序(对无符号长型进行 *** 作 8bytes)ntons()——"NetWork to Host short",网络字节序转换为主机字节顺序(对无符号短型进行 *** 作 4bytes)ntohl()——"NetWork to Host Long",网络字节顺序转换为主机字节顺序(对无符号长型进行 *** 作 8bytes)例如:*.sin_addr.s_addr = htonl(innaddr_any)是什么意思?*.sin_addr.s_addr = htonl(innaddr_any)是Socket编程中用到的。*是任意定义的一个sockaddr_in型的结构体对象sin_addr是他的一个属性,用于定义IP地址,是strcut in_addr型的,s_addr为结构体in_addr的对象,简单说就是三个结构体嵌套包装的一个包。inaddr_any一般为内核指定的,大多数系统取0,表示任意的IP地址。htonl()简单说是把一个本机IP转化为网络协议中规定的格式的函数,也就是所谓的大端模式或小端模式。 htons函数是将一个u_short类型的值从主机字节顺序转换为TCP/IP的网络字节顺序,原型声明如下:u_short htons(u_short hostshort)htonl函数是将一个u_long的值从主机字节顺序转换为TCP/IP的网络字节顺序,原型声明如下:u_long htonl(u_long hostlong)字节序和网络平台有关,不同的平台,字节序不同。(字节序顾名思义——字节的排列顺序)只有多于一个字节的数据类型,才有字节序的问题,比如short或者int类型。char是没有这个问题的。字节序就是在硬件里面,一般实在内存里,如何表示存储和表示这些数据类型。如果高字节放到高地址上,就是大端(big endian),如果高字节放到低地址上,就是小端模式(little endian)。

如何确认系统是采用大端还是小端**

1、大小端

**大端(存储)模式:**是指一个数据的低位字节序的内容放在高地址处,高位字节序存的内容放在低地址处。

如:一个数0x12345678存放在一个4字节空间里

**小端(存储)模式:**是指一个数据的低位字节序内容存放在低地址处,高位字节序的内容存放在高地址处。(可以总结为“小小小”即低位、低地址、小端)

如:一个数0x12345678存放在一个4字节空间里

      在计算机系统中,我们是以字节为单位存放数据的,每个地址单元都对应着一个字节,一个字节为8bit。但在C语言中存在不同的数据类型,占用的字节数也各不相同,那么就存在怎样存放多个字节的问题,因此就出现了大端存储模式和小端存储模式。

    大小端是由CPU和 *** 作系统来决定的,在 *** 作系统中,x86和一般的OS(如windows,FreeBSD,Linux)使用的是小端模式,但比如Mac OS是大端模式。

知道为什么有模式的存在,下面需要了解下具有有什么应用场景:

1)不同端模式的处理器进行数据传递时必须要考虑端模式的不同

2)在网络上传输数据时,由于数据传输的两端对应不同的硬件平台,采用的存储字节顺序可能不一致。所以在TCP/IP协议规定了在网络上必须采用网络字节顺序,也就是大端模式。对于char型数据只占一个字节,无所谓大端和小端。而对于非char类型数据,必须在数据发送到网络上之前将其转换成大端模式。接收网络数据时按符合接受主机的环境接收。

2、如果知道当前系统是采用的什么模式:

1)     

通过查看一个变量在内存中存放的位置来判断

int test1_endian() {

    int i = 1

    char *a = (char *)&i

    if (*a == 1)

        printf("小端\n")

    else

        printf("大端\n")

    return 0

}

2、用联合体

int test2_endian() {

      union {

              int i

              char c

      }un

      un.i = 1

      if(un.c == 1) {

              printf("小端")

      }

      else {

              printf("大端")

      }

      return 0

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/yw/8287277.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-15
下一篇2023-04-15

发表评论

登录后才能评论

评论列表(0条)

    保存