客户端:

  1. #include <iostream>
  2. #include <boost/asio.hpp>
  3. #include <boost/bind.hpp>
  4. #include <boost/shared_ptr.hpp>
  5. #include <boost/enable_shared_from_this.hpp>
  6. using boost::asio::ip::tcp;
  7. using boost::asio::ip::address;
  8. class session: public boost::enable_shared_from_this<session> {
  9. public:
  10. session(boost::asio::io_service &io_service, tcp::endpoint &endpoint)
  11. : io_service_(io_service), socket_(io_service), endpoint_(endpoint)
  12. {
  13. }
  14. void start() {
  15. socket_.async_connect(endpoint_,
  16. boost::bind(&session::handle_connect,
  17. shared_from_this(),
  18. boost::asio::placeholders::error));
  19. }
  20. private:
  21. void handle_connect(const boost::system::error_code &error) {
  22. if (error) {
  23. if (error.value() != boost::system::errc::operation_canceled) {
  24. std::cerr << boost::system::system_error(error).what() << std::endl;
  25. }
  26. socket_.close();
  27. return;
  28. }
  29. static tcp::no_delay option(true);
  30. socket_.set_option(option);
  31. strcpy(buf, "Hello World!\n");
  32. boost::asio::async_write(socket_,
  33. boost::asio::buffer(buf, strlen(buf)),
  34. boost::bind(&session::handle_write,
  35. shared_from_this(),
  36. boost::asio::placeholders::error,
  37. boost::asio::placeholders::bytes_transferred));
  38. }
  39. void handle_write(const boost::system::error_code& error, size_t bytes_transferred) {
  40. memset(buf, sizeof(buf), 0);
  41. boost::asio::async_read_until(socket_,
  42. sbuf,
  43. "\n",
  44. boost::bind(&session::handle_read,
  45. shared_from_this(),
  46. boost::asio::placeholders::error,
  47. boost::asio::placeholders::bytes_transferred));
  48. }
  49. void handle_read(const boost::system::error_code& error, size_t bytes_transferred) {
  50. std::cout << buf << std::endl;
  51. }
  52. private:
  53. boost::asio::io_service &io_service_;
  54. tcp::socket socket_;
  55. tcp::endpoint &endpoint_;
  56. char buf[1024];
  57. boost::asio::streambuf sbuf;
  58. };
  59. typedef boost::shared_ptr<session> session_ptr;
  60. int main(int argc, char* argv[])
  61. {
  62. boost::asio::io_service io_service;
  63. tcp::endpoint endpoint(address::from_string("192.168.1.1"), 10028);
  64. session_ptr new_session(new session(io_service, endpoint));
  65. new_session->start();
  66. io_service.run();
  67. return 0;
  68. }

服务器:

  1. #include <string.h>
  2. #include <boost/asio.hpp>
  3. #include <boost/bind.hpp>
  4. #include <boost/shared_ptr.hpp>
  5. #include <boost/enable_shared_from_this.hpp>
  6. using boost::asio::ip::tcp;
  7. using boost::asio::ip::address;
  8. class session: public boost::enable_shared_from_this<session> {
  9. public:
  10. session(boost::asio::io_service &io_service): socket_(io_service)
  11. {
  12. }
  13. void start() {
  14. static tcp::no_delay option(true);
  15. socket_.set_option(option);
  16. boost::asio::async_read_until(socket_,
  17. sbuf_,
  18. "\n",
  19. boost::bind(&session::handle_read,
  20. shared_from_this(),
  21. boost::asio::placeholders::error,
  22. boost::asio::placeholders::bytes_transferred));
  23. }
  24. tcp::socket &socket() {
  25. return socket_;
  26. }
  27. private:
  28. void handle_write(const boost::system::error_code& error, size_t bytes_transferred) {
  29. boost::asio::async_read_until(socket_,
  30. sbuf_,
  31. "\n",
  32. boost::bind(&session::handle_read,
  33. shared_from_this(),
  34. boost::asio::placeholders::error,
  35. boost::asio::placeholders::bytes_transferred));
  36. }
  37. void handle_read(const boost::system::error_code& error, size_t bytes_transferred) {
  38. boost::asio::async_write(socket_,
  39. sbuf_,
  40. boost::bind(&session::handle_write,
  41. shared_from_this(),
  42. boost::asio::placeholders::error,
  43. boost::asio::placeholders::bytes_transferred));
  44. }
  45. private:
  46. tcp::socket socket_;
  47. boost::asio::streambuf sbuf_;
  48. };
  49. typedef boost::shared_ptr<session> session_ptr;
  50. class server {
  51. public:
  52. server(boost::asio::io_service &io_service, tcp::endpoint &endpoint)
  53. : io_service_(io_service), acceptor_(io_service, endpoint)
  54. {
  55. session_ptr new_session(new session(io_service_));
  56. acceptor_.async_accept(new_session->socket(),
  57. boost::bind(&server::handle_accept,
  58. this,
  59. new_session,
  60. boost::asio::placeholders::error));
  61. }
  62. void handle_accept(session_ptr new_session, const boost::system::error_code& error) {
  63. if (error) {
  64. return;
  65. }
  66. new_session->start();
  67. new_session.reset(new session(io_service_));
  68. acceptor_.async_accept(new_session->socket(),
  69. boost::bind(&server::handle_accept,
  70. this,
  71. new_session,
  72. boost::asio::placeholders::error));
  73. }
  74. void run() {
  75. io_service_.run();
  76. }
  77. private:
  78. boost::asio::io_service &io_service_;
  79. tcp::acceptor acceptor_;
  80. };
  81. int main(int argc, char* argv[])
  82. {
  83. boost::asio::io_service io_service;
  84. tcp::endpoint endpoint(address::from_string("192.168.1.1"), 10028);
  85. server s(io_service, endpoint);
  86. s.run();
  87. return 0;
  88. }

编译:
g++ -Wall -o client client.cpp -lboost_system
g++ -Wall -o server server.cpp -lboost_system

这里需要注意的是: async_write, async_read, async_read_until 都是需要达到特定条件才会调用回调函数,
在调用回调函数之前, 不能再次调用, 否则接收到的数据很可能是乱的. 所以, 在实际代码当中, 会有一个写缓冲队列, 当需要write的时, 先放到队列中, 如果队列个数为1, 则调用async_write, 否则等待函数回调, 当函数回调时将首个元素从队列中移除, 然后接着发送下一个, 直到队列为空.

对于client, 由于is_open在async_connect之后就是true状态了, 因此在async_connect回调返回之前没有方法知道是否已经连接成功, 实际代码当中一般会增加一个变量以表示该套接字是否已经允许发送数据.

boost asio 简单示例相关推荐

  1. Boost.Asio入门

    原文地址:https://mmoaay.gitbooks.io/boost-asio-cpp-network-programming-chinese/content/Chapter1.html Boo ...

  2. Boost:组合异步操作的简单示例

    Boost:组合异步操作的简单示例 实现功能 C++实现代码 实现功能 boost::asio模块,组合异步操作的简单示例 C++实现代码 #include <boost/asio/io_con ...

  3. BOOST使用 proto::extends 扩展终端类型的简单示例

    BOOST使用 proto::extends 扩展终端类型的简单示例 实现功能 C++实现代码 实现功能 BOOST使用 proto::extends 扩展终端类型的简单示例 C++实现代码 #inc ...

  4. BOOST使用 proto 转换进行任意类型操作的简单示例

    BOOST使用 proto 转换进行任意类型操作的简单示例 实现功能 C++实现代码 实现功能 BOOST使用 proto 转换进行任意类型操作的简单示例 C++实现代码 #include <i ...

  5. boost::proto模块实现构建算术表达式的简单示例 带有占位符的评估器的测试程序

    boost::proto模块实现构建算术表达式的简单示例带有占位符的评估器的测试程序 实现功能 C++实现代码 实现功能 boost::proto模块实现构建算术表达式的简单示例带有占位符的评估器的测 ...

  6. boost::math模块演示负二项分布使用的简单示例的测试程序

    boost::math模块演示负二项分布使用的简单示例的测试程序 实现功能 C++实现代码 实现功能 boost::math模块演示负二项分布使用的简单示例的测试程序 C++实现代码 #include ...

  7. 使用 Boost.Math 计算 Jacobi Zeta 函数的简单示例, 并使用相应的 WolframAlpha 命令

    使用 Boost.Math 计算 Jacobi Zeta 函数的简单示例, 并使用相应的 WolframAlpha 命令 实现功能 C++实现代码 实现功能 使用 Boost.Math 计算 Jaco ...

  8. boost::math模块计算二项式随机变量的概率和分位数的简单示例

    boost::math模块计算二项式随机变量的概率和分位数的简单示例 实现功能 C++实现代码 实现功能 boost::math模块计算二项式随机变量的概率和分位数的简单示例 C++实现代码 #inc ...

  9. boost::icl模块interval_map 的最简单示例是重叠计数器

    boost::icl模块interval_map 的最简单示例是重叠计数器 实现功能 C++实现代码 实现功能 boost::icl模块interval_map 的最简单示例是重叠计数器 C++实现代 ...

最新文章

  1. <马哲>科学技术在社会发展中的作用2017-12-27
  2. 存储世界瞬息万变 SSD掀行业浪潮
  3. 04-图像的形状绘制
  4. linux系统进程类型不包括,linux期末考试练习题
  5. Java局域网对战游戏、天气预报项目
  6. python字符串操作总结_Python字符串的一些操作方法总结
  7. HDOJ--1203--I NEED A OFFER!
  8. CloudStack 4.4学习总结之注册ISO
  9. GoLang 插件化开发
  10. 肯耐珂萨java_站在尤里奇的肩膀上,肯耐珂萨探讨适用于国内的HR胜任力模型
  11. 利用WebSphere Edge Server构建冷轧系统负载均衡
  12. 在墨刀中使用思维导图
  13. cearte-react-app中craco中优雅引入svg【自定义宽、高、颜色,仅需5步】
  14. 机器学习:导数与偏导数的区别.
  15. CodeForces - 616C The Labyrinth dfs+暴力
  16. 新手C语言开发详细教程
  17. 兰伯特(Lambert)方程的求解算法3
  18. html js 在线预览 pdf word xls等
  19. 关于operator bool () 和bool operator ==()
  20. 微信朋友圈数据库模式如何设计的?

热门文章

  1. access2013数据库实验笔记_医学科研实验基础知识笔记(十):甲基化
  2. 多线程共用全局变量可能存在的威胁
  3. 【自动驾驶】3. DDS 数据分发服务(Data Distribution Service)
  4. windows下安装python+eclipse
  5. Java 面试知识点解析(三)——JVM篇
  6. MySql 里的IFNULL、NULLIF和ISNULL用法
  7. spring里头各种获取ApplicationContext的方法
  8. elasticsearch插件大全(不断更新)
  9. 鸟哥的Linux私房菜(服务器)- 簡易 Cluster 架設
  10. boost源码剖析之:Tuple Types(rev#2)