boost库asio详解8——几个TCP的简单例子
同步客户端
- void test_asio_synclient()
- {
- typedef boost::asio::io_service IoService;
- // 该命名空间下有几个常用类: accetpt, resolver, endpoint, socket
- typedef boost::asio::ip::tcp TCP;
- try
- {
- IoService ios;
- boost::system::error_code error;
- // 1. 用解释器的方法, 常用来解析域名, 如
- // query("www.163.com","80"), 也可以 query("www.163.com","telnet")
- // echo 7/tcp
- // ftp 21/tcp # File Transfer Protocol (Control)
- // telnet 23/tcp # Virtual Terminal Protocol
- // smtp 25/tcp # Simple Mail Transfer Protocol
- // time 37/tcp timeserver # Time
- // TCP::resolver resolver(ios);
- // TCP::resolver::query query("127.0.0.1", "10000");
- // TCP::resolver::iterator endpoint_iterator = resolver.resolve(query);
- // TCP::resolver::iterator end;
- // TCP::socket socket(ios);
- // socket.connect(*endpoint_iterator, error);
- // 2. 用简便的方法
- TCP::socket socket(ios);
- TCP::endpoint endpoint(boost::asio::ip::address_v4::from_string("127.0.0.1"), 10000);
- socket.connect(endpoint, error);
- // 这里要判断一下, 否则没有连上会通过.
- if (error)
- throw boost::system::system_error(error);
- while(true)
- {
- // boost::array<char, 128> buf;
- std::vector<char> buf(128);
- size_t len = socket.read_some(boost::asio::buffer(buf), error);
- // 这是也要判断一下, 否则服务端运行断开, 这里会出现死循环.
- if (error == boost::asio::error::eof)
- break; // Connection closed cleanly by peer.
- else if (error)
- throw boost::system::system_error(error); // Some other error.
- // buf要注意控制大小。
- socket.write_some(boost::asio::buffer(buf, len), error);
- }
- }
- catch (std::exception& e)
- {
- PRINT_DEBUG(e.what());
- }
- }
同步服务端
- namespace
- {
- std::string make_daytime_string()
- {
- using namespace std; // For time_t, time and ctime;
- time_t now = time(0);
- return ctime(&now);
- }
- }
- void test_asio_synserver()
- {
- typedef boost::asio::io_service IoService;
- typedef boost::asio::ip::tcp TCP;
- try
- {
- IoService ios;
- /*
- *以下构造函数相当于以下步骤
- * basic_socket_acceptor<tcp> acceptor(io_service);
- * acceptor.open(tcp::v4());
- * acceptor.bind(tcp::endpoint(13));
- * acceptor.listen(0);//default
- */
- /*
- tcp::endpoint(端点)由以下三个部分组成
- 1. IP地址(address, address_v4, address_v6)
- 2. 端口号
- 3. 协议版本
- */
- TCP::acceptor acceptor(ios, TCP::endpoint(TCP::v4(), 13));
- for (;;)
- {
- TCP::socket socket(ios);
- acceptor.accept(socket);
- std::string message = make_daytime_string();
- boost::system::error_code ignored_error;
- boost::asio::write(socket,
- boost::asio::buffer(message),
- boost::asio::transfer_all(),
- ignored_error);
- PRINT_DEBUG(message);
- }
- }
- catch (std::exception& e)
- {
- std::cout << e.what() << std::endl;
- }
- }
异步服务端
- namespace
- {
- typedef boost::asio::io_service IoService;
- typedef boost::asio::ip::tcp TCP;
- std::string make_daytime_string()
- {
- using namespace std;
- time_t now = std::time(NULL);
- return ctime(&now);
- }
- class tcp_connection
- : public boost::enable_shared_from_this<tcp_connection>
- {
- public:
- typedef boost::shared_ptr<tcp_connection> pointer;
- static pointer create(IoService& io_service)
- {
- return pointer(new tcp_connection(io_service));
- }
- TCP::socket& socket()
- {
- return socket_;
- }
- void start()
- {
- message_ = make_daytime_string();
- boost::asio::async_write(
- socket_,
- boost::asio::buffer(message_),
- boost::bind(&tcp_connection::handle_write,
- shared_from_this(),
- boost::asio::placeholders::error,
- boost::asio::placeholders::bytes_transferred));
- }
- private:
- tcp_connection(IoService& io_service)
- : socket_(io_service)
- {
- }
- void handle_write(const boost::system::error_code& /*error*/,
- size_t /*bytes_transferred*/)
- {
- PRINT_DEBUG("write data!!!");
- }
- TCP::socket socket_;
- std::string message_;
- };
- class tcp_server
- {
- public:
- tcp_server(IoService& io_service)
- : acceptor_(io_service, TCP::endpoint(TCP::v4(), 10000))
- {
- start_accept();
- }
- private:
- void start_accept()
- {
- tcp_connection::pointer new_connection =
- tcp_connection::create(acceptor_.get_io_service());
- acceptor_.async_accept(
- new_connection->socket(),
- boost::bind(&tcp_server::handle_accept,
- this,
- new_connection,
- boost::asio::placeholders::error));
- }
- void handle_accept(tcp_connection::pointer new_connection,
- const boost::system::error_code& error)
- {
- if (!error)
- {
- new_connection->start();
- start_accept();
- }
- }
- TCP::acceptor acceptor_;
- };
- }
- // tcp_connection与tcp_server封装后
- void test_asio_asynserver()
- {
- try
- {
- IoService io_service;
- tcp_server server(io_service);
- // 只有io_service类的run()方法运行之后回调对象才会被调用
- io_service.run();
- }
- catch (std::exception& e)
- {
- std::cerr << e.what() << std::endl;
- }
- }
boost库asio详解8——几个TCP的简单例子的更多相关文章
- boost库asio详解1——strand与io_service区别
namespace { // strand提供串行执行, 能够保证线程安全, 同时被post或dispatch的方法, 不会被并发的执行. // io_service不能保证线程安全 boost::a ...
- 【Boost】boost库asio详解5——resolver与endpoint使用说明
tcp::resolver一般和tcp::resolver::query结合用,通过query这个词顾名思义就知道它是用来查询socket的相应信息,一般而言我们关心socket的东东有address ...
- 【Boost】boost库asio详解3——io_service作为work pool
无论如何使用,都能感觉到使用boost.asio实现服务器,不仅是一件非常轻松的事,而且代码很漂亮,逻辑也相当清晰,这点上很不同于ACE.使用io_service作为处理工作的work pool,可以 ...
- 【Boost】boost库asio详解2——io_service::run函数无任务时退出的问题
io_service::work类可以使io_service::run函数在没有任务的时候仍然不返回,直至work对象被销毁. void test_asio_nowork() { boost::asi ...
- Python爬虫之selenium库使用详解
Python爬虫之selenium库使用详解 本章内容如下: 什么是Selenium selenium基本使用 声明浏览器对象 访问页面 查找元素 多个元素查找 元素交互操作 交互动作 执行JavaS ...
- STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解)
目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) 前面 ...
- 《TCP-IP详解卷3:TCP 事务协议、HTTP、NNTP和UNIX域协议》【PDF】下载
TCP-IP详解卷3:TCP 事务协议.HTTP.NNTP和UNIX域协议>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230062539 ...
- Boost::bind使用详解
1.Boost::bind 在STL中,我们经常需要使用bind1st,bind2st函数绑定器和fun_ptr,mem_fun等函数适配器,这些函数绑定器和函数适配器使用起来比较麻烦,需要根据是全局 ...
- Boost::split用法详解
工程中使用boost库:(设定vs2010环境)在Library files加上 D:\boost\boost_1_46_0\bin\vc10\lib在Include files加上 D:\boost ...
随机推荐
- thinkphp,onethink,thinkox验证码不显示
使用验证码的时候,一开始正常,后来不显示了 网上说是utf-8的编码问题,什么bom去掉,转化为无bom的格式 我都试了,没用 后来知道是在调用验证码的地方 写上 Public function v ...
- POST提交数据时四种常见的数据格式
最近项目部署到新环境tomcat+mysql,想看看项目部署成功没有,就用soupui调对应接口开测试,soupui使用比较简单,给上接口地址,入参xml报文,把入参的media Type设置为app ...
- [Java开发之路](15)注解
1. 简单介绍 注解(也被称为元数据),为我们在代码中加入信息提供了一种形式化的方法. 注解在一定程度上是把元数据与源码文件结合在一起,而不是保存在外部文档中这一大趋势之下所催生的. 它能够提供用来完 ...
- 【Bash百宝箱】Linux shell学习
shell特点-- Linux有多种shell能够使用,默认的为bash,bash有以下几个主要特点. 1.命令记忆能力 在命令行中按上下键能够找到一个前/后输入的命令.这些命令记录在-/.bash_ ...
- GCD网络多线程---同步运行,异步运行,串行队列,并行队列
总结:同步(无论是串行还是并行)----不又一次开辟子线程 异步(无论是串行还是并行)----开辟子线程 GCD: dispatch queue 主线程的main queue 并行队列 global ...
- Wow6432Node(32位程序的注册表内容都在这个节点下,也可直接使用%systemroot%\syswow64\regedit进行编辑)
64 位版本 Windows 中的注册表分为 32 位注册表项和 64 位注册表项.许多 32 位注册表项与其相应的 64 位注册表项同名,反之亦然. 64 位版本 Windows 包含的默认 64 ...
- html5-8 如何控制html5中的视频标签和音频标签
html5-8 如何控制html5中的视频标签和音频标签 一.总结 一句话总结:找到视频或者音频的element对象,然后查手册看对应的方法或者属性就可以,里面有控制的. 1.如何控制html5中的视 ...
- Thinking in UML 学习笔记(二)——UML核心视图之用例图
在UML中,需求模型又称为用例模型,它主要用于描述系统的功能性需求,即软件可以实现的功能,如登录.注册.入库.出库.查看库存报表.增加员工信息等.常规的用例建模一般包括两个组成部分:绘制用例图和编写用 ...
- tcp注意点
tcp注意点 tcp服务器一般情况下都需要绑定,否则客户端找不到这个服务器 tcp客户端一般不绑定,因为是主动链接服务器,所以只要确定好服务器的ip.port等信息就好,本地客户端可以随机 tcp服务 ...
- 【t097】寄存器
Time Limit: 1 second Memory Limit: 128 MB [问题描述] 蠕虫是一个古老的电脑游戏,它有许多版本.但所有版本都有一个共同的规则:操纵一 条蠕虫在屏幕上转圈,并试 ...