因为使用read()将数据读到不连续的内存、使用write()将不连续的内存发送出去,要经过多次的调用read、write。
如果要从文件中读一片连续的数据至进程的不同区域,有两种方案:
但是多次系统调用+拷贝会带来较大的开销,所以UNIX提供了另外两个函数—readv()和writev(),它们只需一次系统调用就可以实现在文件和进程的多个缓冲区之间传送数据,免除了多次系统调用或复制数据的开销。这两个函数可以用于套接字及任何类型的文件描述符。
writev将多个数据存储在一起,将驻留在两个或更多的不连接的缓冲区中的数据一次写出去。在一次函数调用中,以顺序iov[0]、iov[1]至iov[iovcnt-1]从各缓冲区中聚集输出数据到fd。
#include
ssize_t writev( int fd, const struct iovec *iov, int iovcnt);
返回值:传输字节数,出错时返回-1.
参数说明:
iov是一组iovec结构的指针,iovec结构如下:
struct iovec {
char *iov_base; /*基本地址[指针](https://baike.baidu.com/item/指针),指向缓冲区*/
size_t iov_len; /*指定缓冲区长度*/
};
说明:这个定义取自FreeBSD系统,许多系统现在定义基本地址指针为void *iov_base,其中iov_base为缓冲区首地址,iov_len为缓冲区长度。
注意:
#include
ssize_t readv( int fd, const struct iovec *iov, int iovcnt);