当前位置: 首页 > news >正文

嵌入式linux跨平台基于mongoose的TCP C++类的源码

嵌入式linux开发中,需要使用http服务器时,mongoose是个很好的选择,linux,win双平台都支持,代码全开放,简单明了,我非常喜欢这种尽在撑控中的感觉(关于mongoose实现一个小型的http服务,我之前的博客已有说明)。近日,有在linux,win下编写TCP的需求,mongoose当然也能很好的实现tcp。在此做个笔记。

我使用qt5的creator做为主开发界面,为了代码的通用性,我选择用qt creator新建一个non qt project项目,用C++类的方法对mongoose进行封装。因为mongoose本身是支持linux,win双平台的,其本不需做任何改动,即可在双平台下编译成功。但在linux平台下,需要qt项目指定链接pthread库,而在win平台下,需要指定链接Ws2_32网络库,在QT5项目的pro文件中加入以下内容

#CONFIG += linux
CONFIG += WIN32

CONFIG(WIN32){
LIBS += -lWs2_32
}
else{
LIBS += -lpthread
}

编译时,根据不同的平台,设定CONFIG的内容即可实现跨平台的编译

代码本身用到c++11才支持的lamda函数,因此需要编译器支持c++11特性。在win下可用qt5自带的mingw  编译通过,linux下可用gcc4.7(包括交叉编译用的gcc)以上即可编译通过。

在代码中,tcp_server,tcp_client是两个mongoose的tcp的封装类。在使用时,用lamda函数进行server或client的服务开启关闭,连接,断开事件的处理,数据的传送处理等。

tcp_client没啥好说的,基本就是mongoose的简单封装。
tcp_server主要的特点,是还实现了多个tcp连接的管理。mongoose本身也有简单的连接管理,但用c++的方法管理起来更方便。因此这个tcp_server可以支持多个连接的管理,在嵌入式linux中,多个连接的管理不常用,但有时还是需要的。

另外,mongoose是基于事件驱动的,在某个线程中通过mg_mgr_poll函数来实现事件驱动。为方便使用,我在这两个类中,分别使用了一个C++11的thread,并做了线程安全处理。TCP_Server是服务开启各关闭时,同时实现thread的新建和销毁,TCP_Client是在连接和断开时,实现thread的新建和销毁。这样,在使用这两个类时,不用关心线程问题,是要关心数据的接收和处理即可。

在这里我将完整的源码放出来供大家参考、使用。

https://download.csdn.net/download/hugerat/89936871?spm=1001.2014.3001.5503


http://www.mrgr.cn/news/62127.html

相关文章:

  • mysql delete命令操作后,数据库文件大小并未变化,该怎么解决?
  • 隨筆 20241024 Kafka中的ISR列表:分区副本的族谱
  • RustRover加载Rust项目报错
  • C++ | Leetcode C++题解之第514题自由之路
  • HCIP--2 TCP有关笔记
  • [Linux] linux 软硬链接与动静态库
  • SQLark百灵连接——整合项目监控过程
  • 中酱集团:一日三餐吃出健康生活
  • 四、鸿蒙开发-常用布局(线性布局、层叠布局、弹性布局、网格布局、列表布局)
  • C语言导航 3.3指针运算符
  • QT:QThread 使用案例
  • 【Redis:原理、架构与应用】
  • JavaScript 实战技巧:让你成为前端高手的必备知识2
  • 【热管理】日本三洋 sanace 散热风扇
  • 阿里巴巴店铺商品API返回值中的商品分类与筛选条件
  • Docker:存储原理
  • 理解处理器寻址
  • “胖东来”进京赶考,永辉有救了?
  • 睿亚资产郭威:公益路上的坚定行者,照亮希望之光
  • 大数据治理:确保数据价值与合规性的战略框架
  • 【php常用公共函数】php获取指定时间段中有那几年并输出年份的起始时间和结束时间
  • 酱香经典——茅台镇的酱酒“四台”的传奇
  • 姚望篮坛数十秋 巨人肩头月满楼 新篇开启情难舍 篮球梦续望云头
  • Java避坑案例 - 线程池使用中的风险识别与应对
  • 数据分析常用模型:RFM模型、漏斗模型、AARRR模型
  • 肿瘤B细胞图谱的多维探索:三篇前沿研究详解与对比