boost库asio详解6——boost::asio::error的用法浅析

来源:互联网 发布:淘宝亏本卖 编辑:程序博客网 时间:2024/06/17 01:25

1. 概述

一般而言我们创建用于接收error的类型大多声明如下:
[cpp] view plaincopyprint?
  1. boost::system::error_code error  
我们用这个类型去接受在函数中产生的错误, 如: 
[cpp] view plaincopyprint?
  1. socket.connect(endpoint, error);  
如果连接失败,错误类型会保存到error中,比如连接主机失败可能会返回这样的错误
[cpp] view plaincopyprint?
  1. boost::asio::error::host_not_found;  
通过if(error)检测到error后,抛出异常
[cpp] view plaincopyprint?
  1. throw boost::system::system_error(error);  
需要注意的是,我们的error被转化成 system_error了
显示错误很简单了,std::cout << e.what()

2. 异步调用

产生的异常error的传递是个问题,因为异步会立刻返回,局部变量是会被销毁的。而boost::asio::placeholders::error, 将会保存异常的状态,这样我们使用异步调用时如
socket::async_write_some的时候不用自己创建boost::system::error_code error了,直接使用boost::asio::placeholders::error作为参数即可,
同理,我们sync_write_some需要返回读写数据的大小,令人开心的是boost::asio::placeholders::bytes_transferred直接作为参数就可以保存数据大小。
实例如下:
[cpp] view plaincopyprint?
  1. boost::asio::async_write(socket_,  
  2.                          boost::asio::buffer(message_),  
  3.                          boost::bind(&tcp_connection::handle_write, shared_from_this(),  
  4.                          boost::asio::placeholders::error,  
  5.                          boost::asio::placeholders::bytes_transferred));  
参考手册上说的很明确,下面两个类就是为异步调用使用bind的时候设计的。
[cpp] view plaincopyprint?
  1. boost::asio::placeholders::error  
  2. boost::asio::placeholders::bytes_transferred  

3. 同步调用

当然了boost::system::error_code error还用有用的,同步调用的时候我们就用它作为参数。如:
[cpp] view plaincopyprint?
  1. boost::system::error_code error;  
  2. size_t len = socket.read_some(boost::asio::buffer(buf), error);  
同样在异步调用的回调handle中也用它作参数如
[cpp] view plaincopyprint?
  1. void handle_write(const boost::system::error_code& /*error*/,  
  2.                   size_t /*bytes_transferred*/)  
  3. {  
  4. }  

4. 总结

异步就用 boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred
同步就用 boost::system::error_code