linux网络编程七:分散读readv和集中写writev

本文记录了阅读《Linux高性能服务器编程》的心得,重点介绍了readv和writev函数在实现高性能网络编程中的作用。readv用于分散读取,writev则用于集中写入。通过示例展示了一个简单的模拟Web服务器,该服务器使用writev直接将目标文件内容发送给客户端。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在看《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到服务端即可获得该文件。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值