pread,pwrite,read,write区别
2015-09-29 18:43
543 查看
pread, pwrite
#include <unistd.h> // 返回值: 读到的字节数,若已到文件结尾则返回0,若出错返回-1 ssize_t pread(int filedes, void *buf, size_t nbytes, off_t offset); // 返回值: 若成功返回已写的字节数,若出错返回-1 ssize_t pwrite(int filedes, const void *buf, size_t nbytes, off_t offset);
调用pread相当于顺序调用lseek和read,但pread和这种调用又有重大区别:
调用pthread时,无法中断其定位和读操作
不更新文件指针
调用pwrite相当于调用lseek和write,但也与它们有类似区别。
read, write
#include<unistd.h> // 成功:返回读到的字节数;出错:返回-1;文件尾:返回0; ssize_t read (int filedes, void *buf, size_t nbytes );
当从普通文件读时,在读到要求字节数之前已到达了文件尾端。
当从终端设备读时,通常一次最多读一行。
当从网络读时,网络中缓冲机构可能造成返回值小于所要求读的字节数。
当从管道或FIFO读时,如若管道包含的字节少于所需的数量,那么只返回实际用的字节数。
当从某些面向记录的设备读时,一次最多返回一个记录。
当某一信号造成中断,而已经读了部分数据量时。
读操作从文件的当前偏移量处开始,在成功返回之前,该偏移量将增加实际读到的字节数。
#include<unistd.h> // 成功:返回已写的字节数;出错:返回-1; ssize_t write (int filedes, const void *buf, size_t nbytes );
对于普通文件,写操作从文件的当前偏移量处开始
如果在打开该文件时,指定了O_APPEND选项,则在每次写操作之前,将文件偏移量设置在文件的当前结尾处
在一次成功写之后,该文件偏移量增加实际写的字节数
总结:
因为历史上有些系统不支持O_APPEND,才定义了pread和pwrite。因为lseek与read之间,可能会出现非预期的效果,所以定义pread。
随机访问的话,pread/pwrite比较方便。
相关文章推荐
- Linux socket 初步
- linux lsof详解
- linux 文件权限
- 10 篇对初学者和专家都有用的 Linux 命令教程
- Linux 与 Windows 对UNICODE 的处理方式
- Ubuntu12.04下QQ完美走起啊!走起啊!有木有啊!
- 解決Linux下Android开发真机调试设备不被识别问题
- 运维入门
- 运维提升
- Linux 自检和 SystemTap
- Ubuntu Linux使用体验
- c语言实现hashmap(转载)
- Linux 信号signal处理机制
- linux下mysql添加用户
- Scientific Linux 5.5 图形安装教程
- 基于 Linux 集群环境上 GPFS 的问题诊断
- 谁是桌面王者?Win PK Linux三大镇山之宝
- vivi下重新调整分区
- Linux VS Unix:Linux欲一统天下 Unix不死