[C/C++] -- Boost库、Muduo库编译安装使用

1.Muduo库

Muduo 是一个基于 C++11 的高性能网络库,其核心是事件驱动、非阻塞 I/O、线程池等技术,以实现高并发、高性能的网络通信。Muduo 库主要由陈硕先生开发维护,已经成为 C++ 服务器程序员的常用工具之一。

Muduo 库的主要特点:

  1. 事件驱动:Muduo 库采用了事件驱动的方式处理网络事件,通过 epoll 等系统调用实现高效的 I/O 处理。

  2. 非阻塞 I/O:Muduo 库使用了非阻塞 I/O 技术,可以同时处理大量的客户端连接,并且不会阻塞主线程。

  3. 线程池:Muduo 库实现了一个基于线程池的多线程模型,充分利用了多核 CPU 的计算能力,提高了程序的并发处理能力。

  4. 定时器:Muduo 库支持定时器功能,可以方便地实现定时任务,如心跳检测、超时控制等。

  5. 多种协议支持:Muduo 库支持多种常见的网络协议,如 TCP、UDP、HTTP、WebSocket、DNS 等。

  6. 易于使用:Muduo 库提供了简洁易用的 API,方便开发者快速构建高性能的网络应用程序。

源码地址:GitHub - chenshuo/muduo: Event-driven network library for multi-threaded Linux server in C++11

muduo库是基于boost开发的,所以需要先在Linux平台上安装boost库

muduo库源码编译会编译很多unit_test测试用例代码,编译耗时长。很多用不到的测试代码,使用vim编辑CMakeLists.txt文件,注释红框代码。

muduo是用cmake来构建的,需要先安装cmake

sudo apt install cmake

执行build.sh

编译完成后,安装muduo库

 ./build.sh install

此时muduo的头文件和lib库文件不在系统目录下,所以我们手动拷贝到系统目录下

编写测试代码:

/*
muduo网络库给用户提供两个主要的类
TcpServer:用于编写服务器程序
TcpClient:用于编写客户端程序epoll + 线程池
能把网络I/O代码和业务代码区分开用户的连接和断开    用户的可读写事件
*/ 
#include <muduo/net/TcpServer.h>
#include <muduo/net/EventLoop.h>using namespace muduo;
using namespace muduo::net;void onMessage(const TcpConnectionPtr& conn,Buffer* buf, Timestamp receiveTime)
{string msg(buf->retrieveAllAsString());conn->send(msg);
}int main()
{EventLoop loop;TcpServer server(&loop, InetAddress(8000), "EchoServer");server.setMessageCallback(onMessage);server.start();loop. Loop();
}

2.Boost库

Boost 是一个由 C++标准委员会成员发起的、跨平台、开源且免费的 C++ 库集合。Boost 库旨在为 C++ 程序员提供高质量的、可移植的 C++ 库,用于简化 C++ 开发,并扩展 C++ 语言和标准库的功能。Boost 库提供了许多功能强大且经过广泛测试的模块,涵盖了从系统编程到应用级别的各个领域。

  • Boost库下载(zip是Windows版,tar.gz是Linux版)

Boost C++ Libraries

  • Windows环境下搭建Boost库

双击运行bootstrap.bat文件,在同路径下生成b2.exe文件,运行b2.exe进行编译安装(时间较长)。

编译完成后,VS创建C++项目,打开项目“属性”,把路径信息添加到项目属性的包含目录和库目录里面

写下代码测试

#include<iostream>
#include <boost/version.hpp>
#include <boost/config.hpp>
using namespace std;
int main()
{cout << BOOST_VERSION << endl;cout << BOOST_LIB_VERSION << endl;cout << BOOST_STDLIB << endl;cout << BOOST_PLATFORM << endl;cout << BOOST_COMPILER << endl;return 0;
}

  • Linux环境下搭建Boost库

首先拷贝boost.tar.gz到Linux系统某个路径下并解压

tar -zxvf boost_1_69_0.tar.gz

运行bootstrap.sh工程编译构建程序

运行b2程序

将 Boost 的头文件拷贝到 /usr/include/boost 目录下,将库文件拷贝到 /usr/lib 目录下。

sudo ./b2 install

验证是否安装成功boost

#include<iostream>
#include <boost/version.hpp>
#include <boost/config.hpp>
using namespace std;
int main()
{cout << BOOST_VERSION << endl;cout << BOOST_LIB_VERSION << endl;cout << BOOST_STDLIB << endl;cout << BOOST_PLATFORM << endl;cout << BOOST_COMPILER << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/458512.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端工程化之:webpack2-2(内置插件)

目录 一、内置插件 1.DefinePlugin 2.BannerPlugin 3.ProvidePlugin 一、内置插件 所有的 webpack 内置插件都作为 webpack 的静态属性存在的&#xff0c;使用下面的方式即可创建一个插件对象&#xff1a; const webpack require("webpack")new webpack.插件…

Web3智能合约:重新定义商业合作的未来

随着区块链技术的飞速发展&#xff0c;Web3时代正逐渐到来&#xff0c;而其中的智能合约成为推动商业合作变革的关键力量。本文将深入探讨Web3智能合约的概念、特点以及对商业合作未来的巨大影响。 什么是Web3智能合约&#xff1f; 智能合约是一种以代码形式编写、自动执行合同…

React+Echarts实现数据排名+自动滚动+Y轴自定义toolTip文字提示

1、效果 2、环境准备 1、react18 2、antd 4 3、代码实现 原理&#xff1a;自动滚动通过创建定时器动态更新echar的dataZoom属性startValue、endValue&#xff0c;自定义tooltip通过监听echar的鼠标移入移出事件&#xff0c;判断tooltTip元素的显隐以及位置。 1、导入所需组…

【考研数学】选汤家凤1800 还是 张宇1000❓关键看这一点

考研备考&#xff0c;如果没有准备好&#xff0c;真的不要随便开始&#xff0c;因为已经有人开始后悔了&#xff01; 特别是关于考研数学&#xff0c;很多人都不知道该如何刷题&#xff0c;如何选资料&#xff0c;下面我就分享一下我的经验&#xff1a; 关于考研做题&#xf…

RobotFramework报错都是因为什么

1、参数问题FAILKeyword common. Bpm Ui Query Delete Data expected 44 arguments,got 3. 这种报错的意思是&#xff0c;应该有4个参数&#xff0c;实际只展示了3个参数 找对应的解决方案一 可能是入参的时候数量不一致 解决方案二&#xff1a; 对应的参数中间有空格 …

机器学习 | 一文看懂SVM算法从原理到实现全解析

目录 初识SVM算法 SVM算法原理 SVM损失函数 SVM的核方法 数字识别器(实操) 初识SVM算法 支持向量机&#xff08;Support Vector Machine&#xff0c;SVM&#xff09;是一种经典的监督学习算法&#xff0c;用于解决二分类和多分类问题。其核心思想是通过在特征空间中找到一…

Java小区物业管理系统

技术架构&#xff1a; springboot mybatis thymeleaf Mysql5.7 有需要该项目的小伙伴可以私信我你的Q。 功能描述&#xff1a; 控制台、数据库、楼栋管理、单元管理、房屋管理、车位管理、缴费类型、缴费管理、公告管理、维修管理、投诉管理、用户管理 效果图&#xff…

【Linux】环境基础开发工具的使用之gdb详解(三)

前言&#xff1a;上一篇文章中我们讲解了Linux下的gcc与g的使用&#xff0c;今天我们将进一步的学习gdb与makefile来帮我们更好的理解与使用基础开发工具。 &#x1f496; 博主CSDN主页:卫卫卫的个人主页 &#x1f49e; &#x1f449; 专栏分类:Linux的深度刨析 &#x1f448; …

【C生万物】C语言分支和循环语句

&#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 | 《数据结构与算法》 | 《C生万物》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ &#x1f64f;小杨水平有…

最好的方式来预测未来是去创造它。

在辅导企业的过程中&#xff0c;对于「建设性的冲突」持开放态度&#xff0c;这背后反映了一种深刻的系统思考和变革管理的理念。在许多传统工作环境中&#xff0c;「和谐」往往被高度重视&#xff0c;但这种表面的和谐有时会掩盖问题的真相&#xff0c;阻碍组织的深层次变革和…

顺序表、链表相关OJ题(2)

创作不易&#xff0c;友友们给个三连吧&#xff01;&#xff01; 一、旋转数组&#xff08;力扣&#xff09; 经典算法OJ题&#xff1a;旋转数组 思路1&#xff1a;每次挪动1位&#xff0c;右旋k次 时间复杂度&#xff1a;o(N^2) 右旋最好情况&#xff1a;k是n的倍数…

【力扣】快乐数,哈希集合+快慢指针+数学

快乐数原题地址 方法一&#xff1a;哈希集合 定义函数getNext(n)&#xff0c;返回n的所有位的平方和。一直执行ngetNext(n)&#xff0c;最终只有2种可能&#xff1a; n停留在1。无限循环且不为1。 证明&#xff1a;情况1是存在的&#xff0c;如力扣的示例一&#xff1a; 接…