一、使用同步定时器

这个示例程序通过展示如何在一个定时器执行一个阻塞等待。

  1. //makefile
  2. #----------------------------------------------------------
  3. #makefile helloworld测试用例
  4. #
  5. #
  6. #
  7. #
  8. #-----------------------------------------------------------
  9. ggg=g++
  10. exe=asiotimer
  11. #所有的.o文件写在这里
  12. obj = asiotimer.o
  13. #所要关联的cpp文件写在这里
  14. cpp = asiotimer.cpp
  15. #加入库文件
  16. libso = -lboost_thread -lboost_system
  17. $(exe):$(obj)
  18. @echo "链接开始................"
  19. $(ggg) $(libso) -o $(exe) $(obj)
  20. hw.o : $(cpp)
  21. @echo "编译开始................"
  22. $(ggg) -std=c++11 -c $(cpp)
  23. .PHONY : clean cleanall
  24. cleanall:
  25. @echo "开始make all..........."
  26. -rm -rf $(exe) $(obj)
  27. clean:
  28. @echo "开始清理................"
  29. -rm -rf $(obj)

2、asiotimer.h头文件

  1. //asiotimer.h
  2. #ifndef __ASIOTIMER__H__
  3. #define __ASIOTIMER__H__
  4. #include <iostream>
  5. #include <boost/asio.hpp>
  6. //#define BOOST_DATE_TIME_SOURCE
  7. #include "boost/date_time/posix_time/posix_time.hpp"
  8. #endif

3、asiotimer.cpp文件

  1. //asiotimer.cpp
  2. #include "asiotimer.h"
  3. int main()
  4. {
  5. boost::asio::io_service io;
  6. boost::asio::deadline_timer t(io,boost::posix_time::seconds(5));
  7. t.wait();
  8. std::cout<<"hello,world\n";
  9. return 0;
  10. }

二、使用异步定时器示例

本示例程序演示了如何使用Asio的异步回调功能由示例一修改程序 ,开启计时器执行一个异步等待。

1、makefile文件

makefile 与示例一基本相同,只需要修改
exe=asiotest2

#所有的.o文件写在这里
obj = asiotest2.o

#所要关联的cpp文件写在这里
cpp = asiotest2.cpp

2、asiotest2.h

  1. #ifndef __ASIOTEST2__H__
  2. #define __ASIOTEST2__H__
  3. #include <iostream>
  4. #include <boost/asio.hpp>
  5. #include <boost/date_time/posix_time/posix_time.hpp>
  6. void print(const boost::system::error_code& );
  7. #endif

3、asiotest2.cpp

  1. #include "asiotest2.h"
  2. using namespace std;
  3. using namespace boost;
  4. void print(const boost::system::error_code& )
  5. {
  6. std::cout<<"hello,world!\n";
  7. }
  8. int main()
  9. {
  10. boost::asio::io_service io;
  11. boost::asio::deadline_timer t(io,boost::posix_time::seconds(5));
  12. t.async_wait(&print);
  13. io.run();
  14. return 0;
  15. }

三、绑定参数到处理程序

在本示例中,我们将在示例二修改程序,使定时器每秒被激活一次。这将显示如何传递额外的参数给你的处理函数。

1、makefile 文件同示例二makefile修改方法

2、头文件

  1. #ifndef __ASIOTEST3__H__
  2. #define __ASIOTEST3__H__
  3. #include <iostream>
  4. #include <boost/asio.hpp>
  5. #include <boost/bind.hpp>
  6. #include <boost/date_time/posix_time/posix_time.hpp>
  7. #endif

3、CPP文件

  1. #include "asiotest3.h"
  2. void print(const boost::system::error_code&,
  3. boost::asio::deadline_timer* t,int* count)
  4. {
  5. if(*count<5)
  6. {
  7. std::cout<<*count<<"\n";
  8. ++(*count);
  9. t->expires_at(t->expires_at() + boost::posix_time::seconds(1));
  10. t->async_wait(boost::bind(print,
  11. boost::asio::placeholders::error,t,count));
  12. }
  13. }
  14. int main()
  15. {
  16. boost::asio::io_service io;
  17. int count=0;
  18. boost::asio::deadline_timer t(io,boost::posix_time::seconds(1));
  19. t.async_wait(boost::bind(print,boost::asio::placeholders::error,
  20. &t,&count));
  21. io.run();
  22. std::cout<<"Final count is" <<count<<"\n";
  23. return 0;
  24. }

四、使用成员函数做为处理程序示例

在本示例中,我们将看到如何使用一个类的成员函数作为回调处理程序。

1、makefile 同上面示例

2、头文件

  1. #ifndef __ASIOTEST4__H__
  2. #define __ASIOTEST4__H__
  3. #include <iostream>
  4. #include <boost/asio.hpp>
  5. #include <boost/bind.hpp>
  6. #include <boost/date_time/posix_time/posix_time.hpp>
  7. class printer
  8. {
  9. public:
  10. printer(boost::asio::io_service& io)
  11. :timer_(io,boost::posix_time::seconds(1)),
  12. count_(0)
  13. {
  14. timer_.async_wait(boost::bind(&printer::print,this));
  15. }
  16. ~printer()
  17. {
  18. std::cout<<"Final count is "<<count_<<"\n";
  19. }
  20. void print()
  21. {
  22. if(count_<5)
  23. {
  24. std::cout<<count_<<std::endl;
  25. ++count_;
  26. timer_.expires_at(timer_.expires_at()+boost::posix_time::seconds(1));
  27. timer_.async_wait(boost::bind(&printer::print,this));
  28. }
  29. }
  30. private:
  31. boost::asio::deadline_timer timer_;
  32. int count_;
  33. };

3、cpp文件

  1. #include "asiotest4.h"
  2. int main()
  3. {
  4. boost::asio::io_service io;
  5. printer p(io);
  6. io.run();
  7. return 0;
  8. }

五、多线程的同步处理示例

本示例演示boost::asio::strand 在多线程程序中同步回调处理程

1、makefile同上

2、头文件

  1. #ifndef __ASIOTEST5__H__
  2. #define __ASIOTEST5__H__
  3. #include <iostream>
  4. #include <boost/asio.hpp>
  5. #include <boost/thread/thread.hpp>
  6. #include <boost/bind.hpp>
  7. #include <boost/date_time/posix_time/posix_time.hpp>
  8. class printer
  9. {
  10. public:
  11. printer(boost::asio::io_service& io):strand_(io),
  12. timer1_(io,boost::posix_time::seconds(1)),
  13. timer2_(io,boost::posix_time::seconds(1)),count_(0)
  14. {
  15. timer1_.async_wait(strand_.wrap(boost::bind(&printer::print1,this)));
  16. timer2_.async_wait(strand_.wrap(boost::bind(&printer::print2,this)));
  17. }
  18. ~printer()
  19. {
  20. std::cout<<"Final count is " <<count_<<std::endl;
  21. }
  22. void print1()
  23. {
  24. if(count_ < 10)
  25. {
  26. std::cout<<"Timer 1: "<<count_<<std::endl;
  27. ++count_;
  28. timer1_.expires_at(timer1_.expires_at() + boost::posix_time::seconds(1));
  29. timer1_.async_wait(strand_.wrap(boost::bind(&printer::print1,this)));
  30. }
  31. }
  32. void print2()
  33. {
  34. if(count_ < 10)
  35. {
  36. std::cout<<"Timer 2: " <<count_<<std::endl;
  37. ++count_;
  38. timer2_.expires_at(timer2_.expires_at() + boost::posix_time::seconds(1));
  39. timer2_.async_wait(strand_.wrap(boost::bind(&printer::print2,this)));
  40. }
  41. }
  42. private:
  43. boost::asio::strand strand_;
  44. boost::asio::deadline_timer timer1_;
  45. boost::asio::deadline_timer timer2_;
  46. int count_;
  47. };
  48. #endif

3、CPP文件

  1. #include "asiotest5.h"
  2. int main()
  3. {
  4. boost::asio::io_service io;
  5. printer p(io);
  6. boost::thread t(boost::bind(&boost::asio::io_service::run,&io));
  7. io.run();
  8. t.join();
  9. return 0;
  10. }
      from:

http://blog.csdn.net/leitianjun/article/details/25740633

boost库学习随记六:使用同步定时器、异步定时器、bind、成员函数回调处理、多线程的同步处理示例等的更多相关文章

  1. QML学习笔记(六)- 简单计时器和定时器

    做一个简单的qml计时器和定时器,左键触发计时,右键触发定时 GitHub:八至 作者:狐狸家的鱼 本文链接:QML学习笔记(六)- 简单计时器和定时器 左键点击按钮,触发计时器,中键可以暂停计时,同 ...

  2. boost库学习之开篇

    本系列文章使用boost_1.58.0版本. 一.欢迎使用boost C++库 boost致力于提供一个免费的.便携的源代码级的库. 我们重视那些与C++标准一起工作良好的库.boost库将要成为一个 ...

  3. boost库学习之regex

    一.背景 项目中许多地方需要对字符串进行匹配,比如根据指定的过滤字符串来过滤文件名.刚开始是排斥使用boost库的,第一,我不熟悉boost库:第二,如果引入第三方库,就会增加库的依赖,这样的后果是, ...

  4. Boost库学习之旅入门篇

    学习及使用Boost库已经有一段时间了,Boost为我的日常开发中带来了极大的方便,也使得我越来越依赖于boost库了.但boost功能太多,每次使用还是得翻看以前的 资料,所以为了以后可以更方便的使 ...

  5. c++ boost库学习三:实用工具

    noncopyable 大家都知道定义一个空类的时候,它实际包含了构造函数,拷贝构造函数,赋值操作符和析构函数等. 这样就很容易产生一个问题,就是当用户调用A a(“^_^") 或者A c= ...

  6. boost库在工作(39)网络UDP异步服务端之九

    前面创建的UDP服务器和客户端,都是同步的方式,也就是说当接收数据时,不能参与别的事情执行的.如果在一个只有界面线程的程序里,又不想创建多线程,导致复杂程度的增加,在这种情况之下,我们还有一个方案可以 ...

  7. c++ boost库学习一:时间和日期

    timer类 #include <boost\timer.hpp> #include "iostream" using namespace std; int _tmai ...

  8. c++ boost库学习二:内存管理->智能指针

    写过C++的人都知道申请和释放内存组合new/delete,但同时很多人也会在写程序的时候忘记释放内存导致内存泄漏.如下所示: int _tmain(int argc, _TCHAR* argv[]) ...

  9. Python_sklearn机器学习库学习笔记(六) dimensionality-reduction-with-pca

    # 用PCA降维 #计算协方差矩阵 import numpy as np X=[[2,0,-1.4], [2.2,0.2,-1.5], [2.4,0.1,-1], [1.9,0,-1.2]] np.c ...

随机推荐

  1. uva 11137 Ingenuous Cubrency(完全背包)

    题目连接:11137 - Ingenuous Cubrency 题目大意:由21种规模的立方体(r 1~21),现在给出一个体积, 要求计算可以用多少种方式组成. 解题思路:完全背包, 和uva674 ...

  2. pkg-config的用法

    pkg-config的用法 pkg-config pkg-config程序是干什么用的?简单的说就是向用户向程序提供相应库的路径.版本号等信息的程序. 譬如说我们运行以下命令:pkg-config  ...

  3. Android四大组件之Activity详解

    一.Activity的概要说明 我看过Activity的源码,Activity类注释大概是这样解释的:几乎所有的Activity都是与用户交互用的,我想用了一个几乎的意思应该是排除一些纯展示界面吧,因 ...

  4. eclipse修改编译路径

    右击项目--properties--java build path--点击source,修改最下方的路径即可

  5. JavaSE_ 反射 目录(27)

    JavaSE学习总结第27天_反射 & 设计模式 & JDK5.7.8新特性27.01 反射_类的加载概述和加载时机27.02 反射_类加载器的概述和分类27.03 反射_反射概述27 ...

  6. hadoop 主节点存储告警

    之前只他调整过dfs 的存储目录到最大配额的目录,其它没有处理(就是在默认的/ 目录下,而这个目录的存储配额只有50G) 运行一周的时间不到,集群开始告警,查看是目录/ 的存储占用超过了60% 再查看 ...

  7. ASP.NET MVC5 学习笔记-4 OWIN和Katana

    1. Owin OWIN全名:Open Web Interface for .NET. 它是一个说明,而非一个框架,该声明用来实现Web服务器和框架的松耦合.它提供了模块化.轻量级和便携的设计.类似N ...

  8. Hash table in PowerShell

    hashtable is easy to create, access and manipulate. we simply use $hashTable = @{} to create an empt ...

  9. 宣布在日本地区正式发布 Windows Azure

     昨天,我与 Microsoft 日本的集团副总裁 Yasuyuki Higuchi 一同站在台上,宣布在两个新地区正式发布 Windows Azure:日本东部和日本西部.能够亲自见证 Micr ...

  10. 基于Visual C++2013拆解世界五百强面试题--题18-程序结果分析2-终结篇

    第二部分程序结果分析,分析流程还是写入代码注释中 分析下面程序的输出: #include <stdio.h> int main() { char *a = "hello" ...