首页 > 代码库 > f_lseek

f_lseek

我在STM32中移植了fatfs文件系统,实现在SD卡对文件的读写。在普通读写中都没有问题,但是一旦我关闭文件系统,再次打开读写,之前写的数据就被覆盖。比如举个例子:
      u8 tx_buff[]="stm32f107学习!!!"  //发送缓冲1
      u8 tx_buff1[]="文件系统学习!!!!"//发送缓冲2
     FATFA fs;
     FIL  fsrc;
     FRESULT res;//读写状态值
   //初始化代码 都正常 能读到卡容量
      下面开始读写:
      f_mount(0,&fs);//注册文件系统
      res=f_open(&fsrc,"123.txt",FA_OPEN_ALWAYS|FA_WRITE);//如果存在则打开,不存在则创建
       if(res)
         {
          printf("\n\r打开文件错误:\n\r");
          f_close(&fsrc);
          }
    /////////现在写入数据
      res=f_write(&fsrc,tx_buff,BufferSize,&br);  //BufferSize为发送缓冲字节数 
     if(res||br==0)
          {
     printf("\n\r文件写入错误:\n\r");
     f_close(&fsrc);
    }
    f_close(&fsrc);//关闭
//////////////////////////////////////读出数据
    res=f_open(&fsrc,"123.txt",FA_OPEN_ALWAYS|FA_READ);//以读的方式打开
   res=f_read(&fsrc,fil_buffer,BufferSize,&bw); //读取数据
   if(res||bw==0)
          {
          printf("\n\r文件读取错误:\n\r");
       f_close(&fsrc);
        }      /////////////////到目前 读出的数据 正常为stm32f107学习!!!
f_close(&fsrc);//关闭
   res=f_open(&fsrc,"123.txt",FA_OPEN_ALWAYS|FA_WRITE|FA_READ);//   现在以读写的方式打开
   res=f_write(&fsrc,tx_buff1,BufferSize,&br);  //写入发送缓冲1中的数据    
   res=f_read(&fsrc,fil_buffer,BufferSize*2,&bw); //读取数据
   这个时候我以为读出的数据应该是stm32f107学习!!!文件系统学习!!!!
   但是读出来的只有文件系统学习!!!!也就是先前写入的tx_buff中的数据被tx_buff1中的数据覆盖了。
   查看f_open函数发现fp->fptr = 0;fp->dsect = 0;调用后每次打开文件会将指针清零,所以每次都从头写。
   如果追加文件则需要移动文件指针,f_lseek函数则派上用处了。此函数用于文件指针的移动,共有两个参数,第一个参数为文件对象,第二个参数为移动的字节数。在这里则F_LSEEK(&fsrc,fsrc.fsize)指向文件结尾,即可追加文件。注意第二个参数是相对于文件的开始,如F_LSEEK(&fsrc,3000),表示移动到文件开头3000个字节处。灵活使用可以方便的操作文件。

f_lseek