Linux C/C++ 学习日记(56):用户态网络缓存区

注:该文用于个人学习记录和知识交流,如有不足,欢迎指点。

一、用户态网络缓存区是什么?

在用户态定义的缓存区段(发送、接收)

二、有什么用?

发送缓存区:

一次发送不玩,暂存在缓存区中,后续再发送

接收缓存区:

  1. 在TCP中接收的包可能是不完整的(包之间以 \r\n 分隔),暂存在缓存区中直至完整了再处理。
  2. 接收的数据先存在缓存区中,定时再批量处理也行。

三、如何实现

1. 数组

缺点:

  • 频繁挪移数据:每次读完部分数据,就要将剩余数据挪到数组开头
  • 伸缩性差:数组是定长的
  • 内存浪费:有部分内存可能永远都用不到

2. 队列(环形)

ringbuffer

缺点:

  1. 伸缩性差

  2. 内存浪费

tips: 在linux系统中,可以使用writev 或者 readv, 同时操作队尾和队首两块区域。(这样子将两次系统调用合并为1次,可以提高性能)

3. 链式缓存区

chainbuffer

ChainBuffer(也叫「链表缓冲区 / 链式缓存」)是由多个离散的内存块(缓冲区节点)通过链表串联而成的用户态缓存区 ------ 它对外呈现 "连续可读写" 的抽象,实则内部通过链表管理多个独立的小块内存,是解决「动态长度数据缓存」的核心方案(尤其适合网络编程)。

优点:

1. 动态扩容无拷贝开销

线性缓冲区扩容时(如 vector 满了),需要分配更大的连续内存,再把旧数据拷贝过去;而 ChainBuffer 扩容只需新建一个小块内存节点,追加到链表尾部即可,无任何数据拷贝

2. 规避大内存分配风险

单次分配 100MB 连续内存容易失败(内存碎片),但分配 100 个 1MB 的小块内存成功率极高;ChainBuffer 天然适配这种 "小块内存拼接" 的场景。

相关推荐
淬炼之火6 分钟前
笔记:对MoE混合专家模型的学习和思考
人工智能·笔记·学习·语言模型·自然语言处理
juniperhan13 分钟前
Flink 系列第 3 篇:核心概念精讲|分布式缓存 + 重启策略 + 并行度 底层原理 + 代码实战 + 生产规范
大数据·分布式·缓存·flink
talen_hx29620 分钟前
《kafka核心源码解读》学习笔记 Day 02
笔记·学习·kafka
難釋懷28 分钟前
Nginx实现本地缓存查询
nginx·spring·缓存
刘~浪地球28 分钟前
数据库与缓存--Redis 集群架构与优化
数据库·redis·缓存
talen_hx29631 分钟前
《零基础入门Spark》学习笔记 Day 15
大数据·笔记·学习·spark
_李小白35 分钟前
【OSG学习笔记】Day 41: ReadFileCallback 与 WriteFileCallback(自定义文件读取)
java·笔记·学习
知识分享小能手40 分钟前
MongoDB入门学习教程,从入门到精通,MongoDB 持久性完全指南(20)
数据库·学习·mongodb
IT枫斗者43 分钟前
AI Agent 设计模式全景解析:从单体智能到分布式协作的架构演进
人工智能·redis·分布式·算法·spring·缓存·设计模式
老鱼说AI43 分钟前
长文预警!大模型面试:关于大模型微调的进阶与工程部署讲解
人工智能·深度学习·神经网络·学习·自然语言处理·面试·职场和发展