readv和write函数用于在一次函数调用中读,写多个非连续缓冲区。
#include<sys/uio.h>
ssize_t readv(int filedes, const struct iovec *iov, int iovcnt);
ssize_t writev(int filedes, const struct iovec *iov, int iovcnt);
//若成功则返回已读,写的字节数,若出错则返回-1。
这两个函数的第二个参数是指向iovec结构数组的一个指针:
struct iovec{
void *iov_base; //starting address of buffer
size_t iov_len; //size of buffer
}
iov数组中的元素数由iovcnt说明。下图说明了readv和writev的参数和iovec结构。
writev以顺序iov[0],iov[1]至iov[iovcnt-1]从缓冲区中聚集输出数据。writev返回输出的字节总数。
readv则将读入的数据按照上述同样顺序散布到缓冲区中,readv总是先填满一个缓冲区,然后再填写下一个。readv返回读到
的总字节数。如果遇到文件结尾,已无数据可读,则返回0。
实践:
#include <stdio.h>
#include <sys/uio.h>
#include <fcntl.h>
int main(void){
char buf1[5],buf2[10];
struct iovec iov[2];
iov[0].iov_base = buf1;
iov[0].iov_len = 5;
iov[1].iov_base = buf2;
iov[1].iov_len = 10;
int fd = open("a.txt",O_RDWR);
if(fd < 0){
perror("open");
return -1;
}
int rsize = readv(fd, iov, 2);
printf("rsize = %d\n",rsize);
close(fd);
fd = open("b.txt", O_RDWR|O_CREAT, S_IRUSR|S_IWUSR);
if(fd < 0){
perror("open");
return -1;
}
int wsize = writev(fd,iov,2);
printf("wsize = %d\n",wsize);
close(fd);
return 0;
}
root@gmdz-virtual-machine:~# cat a.txt
123451234567890
123451234567890
root@gmdz-virtual-machine:~# ./a.out
rsize = 15
wsize = 15
rsize = 15
wsize = 15
root@gmdz-virtual-machine:~# cat b.txt
123451234567890
123451234567890