fopen /open 区别
UNIX 环境下的 C 对二进制流文件的读写有两套班子: 1) fopen,fread,fwrite ; 2) open, read, write
这里简单的介绍一下他们的区别。
1. fopen 系列是标准的 C 库函数; open 系列是 POSIX 定义的,是 UNIX 系统里的 system call 。
也就是说, fopen 系列更具有可移植性;而 open 系列只能用在 POSIX 的操作系统上。
2. 使用 fopen 系列函数时要定义一个指代文件的对象,被称为 “ 文件句柄 ” ( file handler ),是一个结构体;而 open 系列使用的是一个被称为 “ 文件描述符 ” ( file descriptor )的 int 型整数。
3. fopen 系列是级别较高的 I/O ,读写时使用缓冲;而 open 系列相对低层,更接近操作系统,读写时没有缓冲。由于能更多地与操作系统打交道, open 系列可以访问更改一些 fopen 系列无法访问的信息,如查看文件的读写权限。这些额外的功能通常因系统而异。
4. 使用 fopen 系列函数需要 "#include <sdtio.h>" ;使用 open 系列函数需要 "#include <fcntl.h>" ,链接时要之用 libc ( -lc )
小结:
总的来说,为了使程序获得更好的可移植性,未到非得使用一些 fopen 系列无法实现的功能的情况下, fopen 系列是首选。
read/write 和 fread/fwrite 区别
1,fread 是带缓冲的 ,read 不带缓冲 .
2,fopen 是标准 c 里定义的 ,open 是 POSIX 中定义的 .
3,fread 可以读一个结构 .read 在 linux/unix 中读二进制与普通文件没有区别 .
4,fopen 不能指定要创建文件的权限 .open 可以指定权限 .
5,fopen 返回指针 ,open 返回文件描述符 ( 整数 ).
6,linux/unix 中任何设备都是文件 , 都可以用 open,read.
如果文件的大小是 8k 。
你如果用 read/write ,且只分配了 2k 的缓存,则要将此文件读出需要做 4 次系统调用来实际从磁盘上读出。
如果你用 fread/fwrite ,则系统自动分配缓存,则读出此文件只要一次系统调用从磁盘上读出。
也就是用 read/write 要读 4 次磁盘,而用 fread/fwrite 则只要读 1 次磁盘。效率比 read/write 要高 4 倍。
如果程序对内存有限制,则用 read/write 比较好。
都用 fread 和 fwrite, 它自动分配缓存 , 速度会很快 , 比自己来做要简单。如果要处理一些特殊的描述符 , 用 read 和 write, 如套接口 , 管道之类的
系统调用 write 的效率取决于你 buf 的大小和你要写入的总数量,如果 buf 太小,你进入内核空间的次数大增,效率就低下。而 fwrite 会替你做缓存,减少了实际出现的系统调用,所以效率比较高。
如果只调用一次 ( 可能吗 ?) ,这俩差不多,严格来说 write 要快一点点 ( 因为实际上 fwrite 最后还是用了 write 做真正的写入文件系统工作 ) ,但是这其中的差别无所谓。