FatFs文件系统:f_sync

网站作者2年前FatFs1605

冲洗一个写文件的缓存信息。

FRESULT f_sync ( 
    FIL* FileObject /* 文件对象结构的指针 */
);

参数:

FileObject 待冲洗的打开的文件对象的指针。


返回值:

FR_OK (0)函数成功。

FR_DISK_ERR 由于底层磁盘 I/O 函数中的错误,而导致该函数失败。

FR_INT_ERR 由于一个错误的 FAT 结构或一个内部错误,而导致该函数失败。

FR_NOT_READY 由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。

FR_INVALID_OBJECT 文件对象无效。


描述:

f_sync 函数当_FS_READONLY == 0 时可用。

f_sync 函数和 f_close 函数执行同样的过程,但是文件仍处于打开状态,并且可以继续对文件执行读/写/移动指针操作。这适用于以写模式长时间打开文件,比如数据记录器。定期的或 f_write 后立即执行 f_sync可以将由于突然断电或移去磁盘而导致数据丢失的风险最小化。在 f_close 前立即执行 f_sync 没有作用,因为在 f_close 中执行了 f_sync。换句话说,这两个函数的差异就是文件对象是不是无效的。

相关文章

FatFs文件系统:f_gets

f_gets 从文件中读取一个字符串。char* f_gets (        char* Str, /* 读缓冲区 */        int Size, /* 读缓冲区大小 */     ...

FatFs文件系统:f_mkfs

在驱动器上创建一个文件系统。FRESULT f_mkfs (        BYTE Drive, /* 逻辑驱动器号 */        BYTE PartitioningRule, /* 分区...

FatFs文件系统:f_mount

在 FatFs 模块上注册/注销一个工作区(文件系统对象)FRESULT f_mount (  BYTE Drive, /* 逻辑驱动器号 */  FATFS* FileSystemObject ...

FatFs文件系统:f_read

从一个文件读取数据。FRESULT f_read (      FIL* FileObject, /* 文件对象结构的指针 */      void* Buffer, /* 存储读取数据的缓冲区的...

FatFs文件系统:f_mkdir

创建一个目录。FRESULT f_mkdir (        const XCHAR* DirName /* 目录名的指针 */   );参数:DirName'\0'结尾的字符串指针,该字符串指...

FatFs文件系统:f_stat

获取文件状态。FRESULT f_stat (        const XCHAR* FileName, /* 文件名或目录名的指针 */        FILINFO* FileInfo /*...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。