muduo库的使用

news/2024/12/22 2:58:32/

目录

1、概述

2、基于muduo网络库开发服务器程序步骤

3、代码演示


1、概述

muduo网络库给用户提供了两个主要的类

  • TcpServer:用于编写服务器程序的
  • TcpClient:用于编写客户端程序的

moduo库采用epoll+线程池

好处:能够把网络I/O(  用户的连接和断开  )的代码和业务(用户的可读写事件等)代码区分开

2、基于muduo网络库开发服务器程序步骤

1.组合TcpServer对象

2.创建EventLoop事件循环对象的指针

3.明确TcpServer构造函数需要什么参数,输出ChatServer的构造函数

4.在当前服务器类的构造函数当中,注册处理连接的回调函数和处理读写事件的回调函数

5.设置合适的服务端线程数量,muduo库会自己分配I/O线程和worker线程

3、代码演示

#include <muduo/net/TcpServer.h>
#include <muduo/net/EventLoop.h>
#include <iostream>
#include <functional> //绑定器using namespace std;
using namespace muduo;
using namespace muduo::net;
using namespace placeholders;/*基于muduo网络库开发服务器程序
1.组合TcpServer对象
2.创建EventLoop事件循环对象的指针
3.明确TcpServer构造函数需要什么参数,输出ChatServer的构造函数
4.在当前服务器类的构造函数当中,注册处理连接的回调函数和处理读写事件的回调函数
5.设置合适的服务端线程数量,muduo库会自己分配I/O线程和worker线程
*/class ChatServer
{
public:ChatServer(EventLoop *loop,               // 事件循环const InetAddress &listenAddr, // IP+Portconst string &nameArg)         // 服务器的名字: _server(loop, listenAddr, nameArg), _loop(loop){// 给服务器注册用户连接的创建和断开回调// 当监听到有创建和断开连接的请求时,调用onConnection方法_server.setConnectionCallback(std::bind(&ChatServer::onConnection, this, _1)); //_1参数占位符,命名空间placeholders,onConnection只有一个参数// 给服务器注册用户读写事件回调_server.setMessageCallback(std::bind(&ChatServer::onMessage, this, _1, _2, _3)); //_1,_2,_3,onMessage有3个参数// 设置服务器端的线程数量  1个I/O线程  3个worker线程_server.setThreadNum(4);}// 开启事件循环void start(){_server.start();}private:// 专门处理用户的连接创建和断开   epoll  listenfd  acceptvoid onConnection(const TcpConnectionPtr &conn){if(conn->connected())//连接成功返回true{cout<<conn->peerAddress().toIpPort()<<"->"<<conn->localAddress().toIpPort()<<"state:online"<<endl;}else{cout<<conn->peerAddress().toIpPort()<<"->"<<conn->localAddress().toIpPort()<<"state:offline"<<endl;conn->shutdown();//close(fd)//_loop->quit();//退出epoll,退出服务器}}// 专门处理用户的读写事件void onMessage(const TcpConnectionPtr &conn, // 连接Buffer *buffer,                  // 缓冲区Timestamp time)               // 接收到数据的时间信息{string buf=buffer->retrieveAllAsString();cout<<"recv data:"<<buf<<"time:"<<time.toString()<<endl;conn->send(buf);}TcpServer _server; // #1EventLoop *_loop;  // #2 epoll
};int main()
{EventLoop loop;//epollInetAddress addr("127.0.0.1",6000);ChatServer server(&loop,addr,"ChatServer");server.start();//listenfd  epoll_ctl=>epollloop.loop();//epoll_wait以阻塞方式等待新用户连接,已连接用户的读写事件等return 0;
}

                   


http://www.ppmy.cn/news/1458101.html

相关文章

Spring管理第三方依赖

在开发中&#xff0c;我们常需要根据业务需求导入我们需要的第三方依赖包&#xff0c;本文主要以导入druid数据库来连接池为案例讲解有关spring管理第三方依赖 目录 纯注解文件注入 1.在pom.xml中导入依赖 2.在com.lcyy包下建立一个config包用于配置类的实现 3.在config包下…

【驱动】I2C读写时序

1、I2C总线 I2C使用两条线在主控制器和从机之间通信,SCL(串行时钟线)和SDA(串行数据线),这两条线需接5~10欧上拉电阻,总线空闲空闲时,SCL和SDA处于高电平,I2C总线标准模式速度可以达到100K/S,快速模式可以达到400K/S。 2、状态 I2C总线有四种状态:空闲、启动、忙碌、…

Debian操作系统简史

一&#xff0c;起源和初衷 Debian项目始于1993年&#xff0c;由Ian Murdock发起&#xff0c;他当时是普渡大学的一名学生。Debian的名字来源于Ian Murdock和他的妻子Debra的组合。Debian的核心理念是创建一个完全自由的操作系统&#xff0c;它遵循严格的自由软件指导原则。 二…

react 项目中使用 iconfont

在 iconfont 上面下载喜欢的字体图标&#xff1a;iconfont-阿里巴巴矢量图标库 添加购物车&#xff0c;下载代码&#xff0c;解压。 将 ttf 字体文件添加到项目的某个文件夹&#xff08;这里我的文件夹是 font&#xff09;内 将一些样式放到项目中&#xff08;此时我放入的是…

Docker介绍及使用

Docker简介 Docker 是一种用于开发、部署和运行应用程序的开源平台。它使用容器化技术&#xff0c;将应用程序及其所有依赖项打包到一个轻型的可移植单元中&#xff0c;称为容器。容器可以快速启动、停止和移动&#xff0c;并且可以在各种环境中运行&#xff0c;包括本地计算机…

安装Nox夜神模拟器关闭了HyperV后Docker运行不了怎么办?

1.背景 为了模拟真机&#xff0c;尝试安装了Nox夜神模拟器&#xff0c; 安装过程要求关闭Hyper-V。当时只是在程序安装卸载中关闭了系统服务。以为到时勾选上就好了。操作路径&#xff1a;控制面板\所有控制面板项\程序和功能\启用或关闭Windows功能\Hyper-V。 后来卸载掉了夜神…

系统SLA

SLA&#xff1a;Service-Level-Aggrement&#xff0c;即服务等级协议。常见的4中SLA指标&#xff1a;可用性、准确性、系统容量和延迟。 可用性&#xff08;Availability&#xff09; 可用性指的是系统服务能正常运行所占的时间百分比。 一般情况下&#xff0c;四个9的可用性…

环形链表问题详解

引言 环形链表的题大家都应该做过&#xff0c;如果没有做过可以去某扣上做一下 ,下面有传送门 141. 环形链表 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/linked-list-cycle/submissions/530160081/ 正文 如果在面试的情况下出现了环形链表的题大…