I/O向量(struct iovec)


readv(2)与writev(2)函数都使用一个I/O向量的概念。这是由所包含的文件定义的:



#include <sys/uio.h>


 

头文件定义了struct iovc,其定义如下:



1 struct iovec {
2 ptr_t iov_base; /* Starting address */
3 size_t iov_len; /* Length in bytes */
4 };


 

struct iovec定义了一个向量元素。通常,这个结构用作一个多元素的数组。对于每一个传输的元素,指针成员iov_base指向一个缓冲区,这个缓冲区是存放的是readv所接收的数据或是writev将要发送的数据。成员iov_len在各种情况下分别确定了接收的最大长度以及实际写入的长度。


readv(2)与writev(2)函数这些函数是作为read与write函数的衍生函数而被人所知的。他们以这样的方式进行设计是因为他们可以在一个原子操作中读取或是写入多个缓冲区。这些函数的原型如下:

#include 



1 int readv(int fd, const struct iovec *vector, int count);
2 int writev(int fd, const struct iovec *vector, int count);


 

这些函数需要三个参数:

        要在其上进行读或是写的文件描述符fd

        读或写所用的I/O向量(vector)

        要使用的向量元素个数(count)

这些函数的返回值是readv所读取的字节数或是writev所写入的字节数。如果有错误发生,就会返回-1,而errno存有错误代码。注意,也其他I/O函数类似,可以返回错误码EINTR来表明他被一个信号所中断。


使用writev的例子

下面的程序代码展示了如何使用writev函数将三个独立的C字符串作为一次写操作写入标准输出。



1 /*
2 * writev.c
3 *
4 * Short writev(2) demo:
5 */
6 #include
7 int main(int argc,char **argv)
8 {
9 static char part2[] = "THIS IS FROM WRITEV";
10 static char part3[] = "]\n";
11 static char part1[] = "[";
12 struct iovec iov[3];
13 iov[0].iov_base = part1;
14 iov[0].iov_len = strlen(part1);
15 iov[1].iov_base = part2;
16 iov[1].iov_len = strlen(part2);
17 iov[2].iov_base = part3;
18 iov[2].iov_len = strlen(part3);
19 writev(1,iov,3);
20 return 0;
21 }