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比较方便。