(1)fopen,fseek,fread,ftell,rewind作用和使用方法,大端小端

1.fopen,fseek,fread,ftell,rewind作用和使用方法

  1. fopen - 用于打开文件。

    • 功能:打开一个文件,并返回一个指向FILE类型的指针,用于后续的读写操作。需要指定文件路径和模式(如读、写等)。
    • 示例:
      FILE *file = fopen("example.txt", "r");  // 打开一个用于读取的文件
      if (file == NULL) {
          // 处理错误
      }
      
  2. fseek - 在文件中移动文件指针到一个指定的位置。

    • 功能:设置文件内的位置指针到指定的位置。它需要文件指针、偏移量和起始位置(文件开始、当前位置或文件结尾)作为参数。
    • 示例:
      fseek(file, 0, SEEK_END);  // 将文件指针移动到文件的末尾
      
  3. fread - 从文件中读取数据。

    • 功能:从文件中读取数据到给定的数组中。需要指定要读取的元素大小、元素个数以及文件指针。
    • 示例:
      char buffer[100];
      size_t n = fread(buffer, sizeof(char), 100, file);  // 从文件中读取最多100个字符
      
  4. ftell - 获取当前文件指针的位置。

    • 功能:返回一个long类型的值,表示当前文件指针在文件中的位置。
    • 示例:
      long position = ftell(file);  // 获取当前文件指针的位置
      
  5. rewind - 将文件指针重置回文件的开始位置。

    • 功能:将文件指针重新设置到文件的开始位置。
    • 示例:
      rewind(file);  // 重置文件指针到文件的开始位置
      

2.bin文件里从0x0000到0x0x0007是00 00 DF 00 00 01 00 00,但是用fread读出来前四个字节是DF0000,然后是0x1000,这是为什么?

在这里插入图片描述
在这里插入图片描述

如果你在尝试从一个二进制文件中读取数据,并且遇到了数据似乎被错误地读取或解释的情况,可能的原因包括:

  1. 字节顺序(Endianess)问题:计算机有两种存储多字节数据的方式——大端(Big Endian)和小端(Little Endian)。大端模式是将最高有效字节(MSB)存储在最低的地址上,而小端模式则是将最低有效字节(LSB)存储在最低的地址上。如果文件是在一个大端系统中创建的,然后你尝试在一个小端系统中读取它(大多数现代PC都是小端),那么多字节的数据类型(如整数、浮点数等)就会被错误地解释。

  2. 错误的解释或读取方式:如果你在读取数据时没有正确地解释文件格式或者数据结构,就可能会遇到数据被错误读取的问题。例如,如果文件中的数据是以特定的结构或者需要按特定的字节顺序读取,但读取操作没有考虑到这些因素,就会导致错误的数据解释。

针对你遇到的具体问题,原始数据00 00 DF 00 00 01 00 00应该是按照小端格式存储的。如果你期望读取到的前四个字节是DF0000,但实际上文件内容显示的是00 00 DF 00,这看起来像是一个字节顺序的解释问题。

  • 原始数据按小端格式表示时,00 00 DF 00实际上代表的是0x00DF0000,而不是DF0000
  • 接下来的00 01 00 00在小端格式下代表0x00000100,而不是0x1000。这里可能是你的期望和实际读取/解释方式之间存在误差。

当处理这样的数据时,确保你完全理解了数据的格式(大端还是小端),以及你的程序(或者使用的函数)如何处理这些数据。在C或C++中,如果需要转换字节顺序,可以使用函数如ntohl()ntohs()htonl()htons()来在网络字节顺序和主机字节顺序之间转换。不过,请记住,这些函数主要用于处理网络通信中的字节顺序问题。对于文件I/O操作,你可能需要手动处理或确保以正确的方式解读数据。

从数据手册来看,真正的地址确实是0xDF000000,说明PC端的bin文件确实是按照小端方式存储的。

在这里插入图片描述

3.一个字节8位的传输方式

在通信协议中,MSB(Most Significant Bit,最高有效位)和LSB(Least Significant Bit,最低有效位)通常用来描述一个字节中的位的顺序。一个字节有8位,每个位可以是0或1。MSB是指在数值中具有最高权重的位,而LSB则是指在数值中具有最低权重的位。

考虑一个8位的字节,从左到右依次为第7位到第0位,其中第7位是MSB,第0位是LSB。在二进制数值中,MSB的位置对应着最高的权重,而LSB的位置对应着最低的权重。

例如,考虑二进制数值10110101,其中第7位(最左侧)是MSB,而第0位(最右侧)是LSB。在这个例子中,MSB对应的是1(2的7次方),而LSB对应的是1(2的0次方)。

在通信协议中,MSB和LSB的顺序对于数据的解释至关重要。有时候通信协议会规定MSB在前还是LSB在前,这称为字节顺序或者位序。通常,这个规定是由通信协议或者数据格式决定的。

举例来说,在某些协议中,如果一个字节10110101需要被解释为整数,而且协议规定使用大端字节顺序(MSB在前),那么这个字节被解释为0xD5,即1*2^7 + 0*2^6 + 1*2^5 + 1*2^4 + 0*2^3 + 1*2^2 + 0*2^1 + 1*2^0 = 213。但如果协议规定使用小端字节顺序(LSB在前),那么这个字节被解释为0xAD,即1*2^7 + 0*2^6 + 1*2^5 + 1*2^4 + 0*2^3 + 1*2^2 + 0*2^1 + 1*2^0 = 173

因此,在通信协议中,正确理解和处理MSB和LSB的顺序至关重要,以确保数据能够正确地被解释和处理。

4.不同协议可能用不同的MSB,LSB的约定方式

在SPI(Serial Peripheral Interface)协议中,数据传输的顺序通常由设备间的约定决定。SPI是一种同步串行通信协议,通常由主设备(例如微控制器或者单片机)与一个或多个从设备(例如传感器、存储器等)之间进行通信。

在SPI通信中,数据是通过时钟信号同步传输的。每次传输,数据都是从主设备发送到从设备,同时从设备也会发送数据回主设备。因此,在SPI通信中,主设备和从设备之间需要一致地约定数据传输的顺序,包括是先传输MSB还是先传输LSB。

一般来说,在SPI通信中,数据传输的顺序可以由协议规范、通信设备的文档或者硬件设计中的约定来确定。有些设备可能规定先传输MSB,而有些则可能规定先传输LSB。

因此,如果你正在开发或者使用SPI通信协议,建议查阅相关的设备文档或者通信协议规范,以确定数据传输的顺序。

  • 24
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值