Skip to content

Instantly share code, notes, and snippets.

@qiaohaijun
Last active June 13, 2017 11:46
Show Gist options
  • Save qiaohaijun/2958e4539da99892f93a4a9835ed2dc3 to your computer and use it in GitHub Desktop.
Save qiaohaijun/2958e4539da99892f93a4a9835ed2dc3 to your computer and use it in GitHub Desktop.

简介

  1. #include<sys/uio.h>
  2. iovec 表示i/o向量
  3. readv(2)和 writev(2)函数相关

结构体定义

struct iovec {
  ptr_t iov_base;  /**Starting address/
  size_t iov_len   /*length*/
}

struct iovec 解析

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

readv and writev

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

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

这些函数需要三个参数:

  1. 要在其上进行读或是写的文件描述符fd
  2. 读或写所用的I/O向量(vector)
  3. 要使用的向量元素个数(count)

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


下面的例子演示了如何将三个独立的字符串一次性写入标准输出。

/*
* writev.c
*
* Short writev(2) demo:
*/
#include <sys/uio.h>
int main(int argc,char **argv)
{
    static char part2[] = "THIS IS FROM WRITEV";
    static char part3[]    = "]\n";
    static char part1[] = "[";
    struct iovec iov[3];
    iov[0].iov_base = part1;
    iov[0].iov_len = strlen(part1);
    iov[1].iov_base = part2;
    iov[1].iov_len = strlen(part2);
    iov[2].iov_base = part3;
    iov[2].iov_len = strlen(part3);
    writev(1,iov,3);
    return 0;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment