最近在看《linux高性能服务器编程》,在此做个日记,以激励自己,同时分享于有需要的朋友。
1. 分散读readv 和 集中写writev
readv将数据从文件描述符读到分散的内存块中,即分散读。
writev将多块分散的内存一并写入文件描述符中,即集中写。
#include <sys/uio.h>
ssize_t readv(int fd, const struct iovec *vector, int count);
ssize_t writev(int fd, const struct iovec *vector, int count);
fd参数是被操作的文件描述符。
vector参数是iovec结构体:
#include <sys/uio.h>
struct iovec
{
void *iov_base; //指向一个缓冲区,这个缓冲区是存放readv所接收的数据或是writev将要发送的数据
size_t iov_len; //接收的最大长度以及实际写入的长度
};
count参数是vector数组的长度,即有多少块内存数据需要从fd读出或写到fd。
两者调用成功是返回读出/写入fd的字节数,失败返回-1,并设置errno。类似于简化版的recvmsg和sendmsg
2. 以下简陋的模拟WEB服务器,采用集中写的方式。我省略了HTTP请求的接收及解析, 直接将目标文件作为第3个参数传递给服务端程序,客户端telnet到服务端即可获得该文件。