*免分资源链接点击打开链接http://download.csdn.net/detail/goldenhawking/4492378

有了TCP、线程池,我们就可以把他们连接起来。使用最简单的 QMainWindow吧,设计个UI,而后,创建我们的线程池、Service,并把TcpService 的数据接收信号与线程池的数据处理信号连接起来。

为了模拟处理任务,我们简单的设计一个转换大小写字符的函数作为处理过程的模拟,这样有利于在超级终端调试、模拟。

  1. #ifndef MYTASKITEM_H
  2. #define MYTASKITEM_H
  3. #include "qghthreadtaskitem.h"
  4. class MyTaskItem : public QGHThreadTaskItem
  5. {
  6. Q_OBJECT
  7. public:
  8. MyTaskItem(QObject *parent);
  9. ~MyTaskItem();
  10. public:
  11. virtual void run(QObject * task_source, const QByteArray & data_array);
  12. signals:
  13. void evt_SendData(QObject * objClient,const QByteArray & dtarray);
  14. };
  15. #endif // MYTASKITEM_H

上述的类中的信号用来把处理结果发回生产者(也可以是别的消费者,取决于信号的连接)

  1. void MyTaskItem::run(QObject * task_source, const QByteArray & data_array)
  2. {
  3. QByteArray res;
  4. foreach (char c,data_array)
  5. {
  6. res.push_back((c>='a'&& c<='z')?c+('A'-'a'):c);
  7. if (c==015)
  8. res.push_back(012);
  9. }
  10. emit evt_SendData(task_source,res);
  11. return ;
  12. }

简单的大小写转换,以及为了超级终端设置的换行符格式转换。为了模拟吃力的运算时间,我们加上一个sleep

  1. void MyTaskItem::run(QObject * task_source, const QByteArray & data_array)
  2. {
  3. QByteArray res;
  4. foreach (char c,data_array)
  5. {
  6. res.push_back((c>='a'&& c<='z')?c+('A'-'a'):c);
  7. if (c==015)
  8. res.push_back(012);
  9. }
  10. _sleep (50);
  11. emit evt_SendData(task_source,res);
  12. return ;
  13. }

具体工程参见我的资源, _sleep 在资源中并没有加上。

上几个图,首先是服务端的配置,

设置端口、线程数、是否为每个客户端发来的数据包保持FIFO,以及发回消费者时载荷的大小。而后,启动,运行客户端连接

客户端是一个模拟程序,会模拟N个连接发送数据。当然,在XP下一个程序只许开10个连接。

------------------------------------------

对没有安装VC2010的Windows用户,可以用命令行编译,具体方法。

1、打开QT的命令行

进入文件夹,用命令编译服务端

而后编译客户端

生成的文件在 Debug 和 Release了

如果提示找不到QT的DLL,则可以设置系统路径到QT/BIN

http://blog.csdn.net/goldenhawking/article/details/7854635

QT 线程池 + TCP 小试(三)实现最终功能的更多相关文章

  1. QT 线程池 + TCP 小试(一)线程池的简单实现

    *免分资源链接点击打开链接http://download.csdn.net/detail/goldenhawking/4492378 很久以前做过ACE + MFC/QT 的中轻量级线程池应用,大概就 ...

  2. JUC源码分析-线程池篇(三)ScheduledThreadPoolExecutor

    JUC源码分析-线程池篇(三)ScheduledThreadPoolExecutor ScheduledThreadPoolExecutor 继承自 ThreadPoolExecutor.它主要用来在 ...

  3. JUC源码分析-线程池篇(三)Timer

    JUC源码分析-线程池篇(三)Timer Timer 是 java.util 包提供的一个定时任务调度器,在主线程之外起一个单独的线程执行指定的计划任务,可以指定执行一次或者反复执行多次. 1. Ti ...

  4. Java多线程系列 JUC线程池04 线程池原理解析(三)

    转载 http://www.cnblogs.com/skywang12345/p/3509954.html  https://blog.csdn.net/qq_22929803/article/det ...

  5. C++11消息队列 + Qt线程池 + QRunnable执行任务简单模型

    1.模板类queue,包含头文件<queue>中,是一个FIFO队列. queue.push():在队列尾巴增加数据 queue.pop():移除队列头部数据 queue.font():获 ...

  6. Qt 线程池QThreadPool类、QRunnable类

    QThreadPool类 用来管理 QThreads.此类中的所有函数都是线程安全的. 主要属性: 1.activeThreadCount: 此属性表示线程池中的活动线程数,通过activeThrea ...

  7. Qt线程池

    说明 Qt中可以有多种使用线程的方式: 继承 QThread,重写 run() 接口: 使用 moveToThread() 方法将 QObject 子类移至线程中,内部的所有使用信号槽的槽函数均在线程 ...

  8. java多线程系类:JUC线程池:04之线程池原理(三)(转)

    转载请注明出处:http://www.cnblogs.com/skywang12345/p/3509960.html 本章介绍线程池的生命周期.在"Java多线程系列--"基础篇& ...

  9. 聊聊并发(三)Java线程池的分析和使用

    1.    引言 合理利用线程池能够带来三个好处.第一:降低资源消耗.通过重复利用已创建的线程降低线程创建和销毁造成的消耗.第二:提高响应速度.当任务到达时,任务可以不需要的等到线程创建就能立即执行. ...

随机推荐

  1. jquery 源码学习(四)构造jQuery对象-工具函数

    jQuery源码分析-03构造jQuery对象-工具函数,需要的朋友可以参考下.   作者:nuysoft/高云 QQ:47214707 EMail:nuysoft@gmail.com 声明:本文为原 ...

  2. Go语言并发

    Go语言并发机制初探   Go 语言相比Java等一个很大的优势就是可以方便地编写并发程序.Go 语言内置了 goroutine 机制,使用goroutine可以快速地开发并发程序, 更好的利用多核处 ...

  3. No_Sql总结

    NoSQL简介 NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL",是对不同于传统的关系型数据库的数据库管理系统的统称.在现代的计算系统上每天网络上都 ...

  4. ADO.NET - 批量更新或添加数据

    方法一:使用SqlBulkCopy实现批量更新或添加数据. SqlBulkCopy类一般只能用来将数据批量插入打数据库中,如果数据表中设置了主键,出现重复数据的话会报错,如果没有设置主键,那么将会添加 ...

  5. jQuery怎么选择两个class属性

    Jquery选择多个Class属性: $('.className1,.className2,.className4,.className5')

  6. dp_Pku1887

    <span style="color:#000099;">/* A - 单纯dp 示例 Time Limit:1000MS Memory Limit:30000KB 6 ...

  7. 查看系统中安装了那些dotnet core 的SDK和运行时的命令

    原文:查看系统中安装了那些dotnet core 的SDK和运行时的命令 1.查看SDK dotnet --list-sdks 2.查看运行时 dotnet --list-runtimes 效果如下图 ...

  8. mongdb aggregate 聚合数据

    最近用到的一些mongodb的数据查询方法 及api用法 Aggregate() 数据聚合处理的方法 可以将聚合的一些方法放在其后面的括号中,也可继续以agg.的样式链式加入 aggregate.al ...

  9. RabbitMq核心概念和术语

    简介 越来越多的消息中间件很容易让人产生混淆,在学习一种消息中间件的时候,最好先了解他的几种抽象概念,方便你理解,明白了这些概念,你学习起来的时候也就得心应手,同时也是使用好RabbitMQ的基础. ...

  10. Redis实战:如何构建类微博的亿级社交平台

    微博及 Twitter 这两大社交平台都重度依赖 Redis 来承载海量用户访问.本文介绍如何使用 Redis 来设计一个社交系统,以及如何扩展 Redis 让其能够承载上亿用户的访问规模. 虽然单台 ...