原文:http://home.eeworld.com.cn/my/space-uid-430378-blogid-74720.html
我在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);
}
{
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);
}
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学习!!!
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_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个字节处。灵活使用可以方便的操作文件。