FILE有三种缓存模式,
1.全缓冲
2.无缓冲
3.先缓冲
默认为全缓冲,在第一次fwrite数据时会创建缓冲区,通过fstat方法,获取fd对应的文件系统的block size即st.st_blksize,如果为空,则使用默认的BUFSIZ==1024。
实际测试block size,
Linux 文件系统的block size为4196。
小tf卡的block size为8192
U盘block size为8192,sd卡通过读卡器挂载,block size为16384
全缓冲模式
如果C Buffer已经脏了一部分,就先拷贝一部分数据到C缓存,填满C缓存后,调用write写入数据,然后判断剩下数据是否大于C buffer的大小,如果是就直接调用write。
如果剩下数据小于C buffer的缓存,就拷贝进去。
所以正常情况下,数据大小小于C buffer size,就会循环填充C Buffer,填满之后就调用write写数据。
无缓存模式
循环调用write写数据,每次写1024大小数据,直到写完
每次写 BUFSIZ大小的数据,直到写完。
fflush实现原理:
将C Buffer中缓存的数据调用write一次性写入,如果没有一次性写完,会循环write直到写完。
前言一、open与fopen、close与fclose使用区别
二、read与fread、write与fwrite使用区别
三、lseek与fseek使用
四、creat、fgetc、fputc、feof使用
前言
这是在学习Linux文件系统编程时记录的学习心得、
从来源的角度看,open等函数和fopen等函数有所不同:
open是LUNIX系统调用函数,返回文件描述符(File Descriptor),它是文件在文件描述符表里的索引。
fopen是ANSIC标准中的C语言库函数,在不同的系统中应该调用不同的内核api。返回的是一个指向文件结构的指针。
从移植角度:fopen是C标准函数,有良好的移植性;而open是LUNIX系统调用,移植性有限。如windows下相似的功能使用API函数`CreateFile`。
从适用范围:open返回文件描述符,LUNIX下的一切设备都是以文件的形式 *** 作。如网络套接字、硬件设备等。当然包括 *** 作普通正规文件(Regular File)。fopen是用来 *** 纵普通正规文件(Regular File)
从缓冲角度:open无缓冲,fopen有缓冲。缓冲文件系统是借助文件结构体指针来对文件进行管理,通过文件指针来对文件进行访问。缓冲就是先对缓冲区 *** 作,然后再对文件 *** 作。比如执行写文件的 *** 作时,先将数据写入内存“缓冲区”,待内存“缓冲区”装满再写入文件。非缓冲文件系统依赖于 *** 作系统,通过 *** 作系统的功能对文件进行读写,是系统级的输入输出
一、open与fopen、close与fclose使用区别
open和close搭配使用,fopen和fclose搭配使用
int open(const char *pathname, int flags)
FILE *fopen(const char *path, const char *mode)
open函数返回文件描述符号,是文件的索引,fopen返回文件的指针,通过文件指针来访问
int close(int fd)
int fclose(FILE *fp)
二者使用方式大同小异
二、read与fread、write与fwrite使用区别
ssize_t read(int fd, void *buf, size_t count)
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream)
ssize_t write(int fd, const void *buf, size_t count)
size_t fwrite(const void *ptr, size_t size, size_t nmemb,FILE *stream)
ptr就是缓冲区,fwrite从缓冲区数据写入文件,fread从文件读到缓冲区
read、write返回值是读写的字节大小,fread、fwrite返回值取决于第三个参数:读写次数
三、lseek与fseek使用
off_t lseek(int fd, off_t offset, int whence)
int fseek(FILE *stream, long offset, int whence)
二者使用相同,int whence有三种位置:
SEEK_SET光标指向头部,SEEK_CUR光标指向当前位置,SEEK_END光标指向尾部
offset相对于位置的偏移量,偏移量负数往前移,正数往后移
lseek(fd,0,SEEK_END)利用它的返回值,计算文件大小
四、creat、fgetc、fputc、feof使用
int creat(const char*pathname,mode_t mode)
绝对路径 模式:宏表示 数字
S_IRUSR 4 可读
S_IWUSR 2 可写
S_IXUSR 1 可执行
S_IRWXU 7 可读、写、执行
int fputc(int c, FILE *stream)
写入一个字符到fp文件流中,写多个字符可采用循环一个一个写
int fgetc(FILE *stream)
从文件中得到一个字符,可以循环一个一个得到字符,配合feof
int feof(FILE *stream)
判断是否到达文件流末端,未到达末端返回值是0,到达末端返回值是非0
do
{
c = fgetc(fp)
if( feof(fp) )
{
break
}
printf("%c", c)
}while(1)
复制
参考文章:https://www.cnblogs.com/NickyYe/p/5497659.html
linux
c语言
Linux程序设计:文件I/O系统调用、open函数、creat函数
258阅读·0评论·2点赞
2020年9月3日
文件的顺序读写和随机读写,fgetc、fgets、fputc、fputs、fscanf、fprintf、fread、fwrite等等函数的介绍
367阅读·0评论·2点赞
2022年7月22日
Linux—— *** 作文件的系统调用(open、write、read、close)
245阅读·0评论·0点赞
2022年10月15日
Linux应用编程之fopen()、fclose()、fread()、fwrite()函数
2882阅读·0评论·2点赞
2022年4月22日
Linux文件系统【02】creat,open,close,read,write,lseek;ioctl,fcntl,dup,dup2,自定义创建文件命令
542阅读·0评论·0点赞
2022年3月21日
Linux的系统调用open,write,read,close,及相关总结
880阅读·0评论·0点赞
2018年4月20日
linux 系统调用open和close介绍以及作用和调用关系的理解
451阅读·0评论·0点赞
2022年10月11日
fopen() 与 CreateFile() *** 作文件
1209阅读·0评论·0点赞
2011年11月14日
文件描述符,Linux *** 作系统文件的系统调用 open read write close
734阅读·0评论·0点赞
2022年5月17日
【Linux】文件 *** 作(open/read/write/close)、系统调用与库函数的区别
4273阅读·0评论·5点赞
2019年5月19日
Linux 1.文件编程(open、creat、write、read、lseek)
412阅读·0评论·0点赞
2021年8月16日
Linux文件 *** 作函数open、read、 write、lseek、ftruncate(linuxC编程篇)
1003阅读·1评论·2点赞
2021年5月17日
Centos安装python遇到ln: failed to create symbolic link ‘/usr/bin/python’: File exists
2365阅读·0评论·2点赞
2020年9月9日
【Linux】文件 *** 作函数 fopen、fwrite、fread、fclose、fseek 与 open、write、read、close、lseek
482阅读·0评论·0点赞
2021年8月10日
open、fopen与freopen
1317阅读·0评论·0点赞
2015年11月18日
linux下 c语言 用write open二进制写文件,fread与read的区别---open和fopen的区别--fread函数和fwrite函数...
174阅读·0评论·0点赞
2021年5月17日
LinuxC open() umask close() read() write() lseek() fcntl() ioctl() mmap() ext2 stat() dup() dup2()
49阅读·0评论·0点赞
2021年8月18日
Linux文件系统(四)—— open &read &write &poll
2007阅读·0评论·0点赞
2021年12月1日
python3 文件 *** 作(列出、创建、删除、复制) 文件打开模式
1037阅读·2评论·0点赞
2020年11月6日
去首页
看看更多热门内容
1. 文件write *** 作是原子的,多个进程同时写文件,原理上是没问题的。但是问题会出现在:如果多个进程写文件时是先lseek再write,就会出现覆盖。打开文件时使用append标志可以使先lseek再write这个 *** 作变成原子 *** 作,这样可以避免覆盖。2. 多线程共享一个文件句柄的话,是不会有问题的。
3.
4.linux读写磁盘文件过程中,一般情况下并不是直接 *** 作磁盘上的文件,而是读写内存中的磁盘高速缓存,内核选择合适的时机把脏页同步到磁盘。所以读写文件时不立刻调用io不是因为你说的缓冲区,read和write是没有缓冲区的。
5. fprintf和printf一样,是有缓冲区的,不过大小我不知道,也没必要知道吧。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)