自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(3)
  • 收藏
  • 关注

原创 【学习笔记】从零开始学习Reactor网络服务器设计模式

本文实现了一个基于epoll的单线程Reactor模型网络服务器。Reactor模式通过事件驱动机制将网络IO与业务逻辑解耦,核心组件包括:事件监听(epoll)、回调函数(accept_cb/recv_cb/send_cb)和连接管理结构(conn)。系统采用单事件循环架构,主线程通过epoll_wait监听所有socket事件,触发对应回调处理。相比传统多线程模型,该设计避免了线程切换开销,通过conn_list数组管理连接状态,使用函数指针实现事件分发,支持HTTP/WebSocket等多协议扩展。

2026-04-28 17:33:10 493

原创 【学习笔记】从零理解网络io与io多路复用

本文总结了网络IO与IO多路复用的实现方法,重点对比了select、poll和epoll三种多路复用技术。首先介绍了基础的TCP服务器搭建流程:创建socket→绑定地址→监听连接。然后分析了单线程阻塞IO的局限性,以及多线程模型在高并发时的资源消耗问题。接着详细讲解了select的实现方式,通过维护fd_set集合和maxfd来监控多个连接,但存在遍历开销大的缺点。poll方法改用pollfd数组优化了数据结构,但仍有性能瓶颈。最后使用了epoll实现了io多路复用

2026-04-15 00:41:15 344

原创 【学习笔记】从0理解线程池的实现

从零开始实现了一个小的可使用线程池,该线程池实现了任务队列管理、线程复用和同步机制,避免了线程空转问题。

2026-04-08 18:35:25 313

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除