Boost::Asio::Error的用法浅析
2016-03-17 10:59
531 查看
一般而言我们创建用于接收error的类型大多声明如下:
boost::system::error_code
error 我们用这个类型去接受在函数中产生的错误
如
socket.connect(
endpoint,
error);
如果连接失败,错误类型会保存到error中,比如连接主机失败可能会返回这样的错误
boost::asio::error::host_not_found;
通过if (error)检测到error后,抛出异常
throw boost::system::system_error(error);
需要注意的是,我们的error被 转化成 system_error了
显示错误很简单了,std::cout << e.what() 就哦啦。
大致的异常都是这个步骤进行的,然而还有一点在异步调用的时候,产生的异常error 的传递是个问题,因为异步会立刻返回,局部变量是会被销毁的,
boost::asio::placeholders::error,将会保存异常的状态,这样我们使用异步调用时如
socket::async_write_some的时候不用自己创建boost::system::error_co
error 了,直接使用
boost::asio::placeholders::error作为参数即可,
同理,我们sync_write_some需要返回读写数据的大小,令人开心的是boost::asio::placeholders::bytes_transferred直接作为参数就可以保存数据大小。
实例如下:
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));
}
参考手册上说的很明确, boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred就是为异步调用使用bind的时候设计的。
当然了boost::system::error_co
error还用有用的,同步调用的时候我们就用它作为参数
如:
boost::system::error_code
error;
size_t len
= socket.read_some(boost::asio::buffer(buf),
error);
同样在异步调用的回调handle中也用它作参数如
void
handle_write(const
boost::system::error_code&
/*error*/,
size_t
/*bytes_transferred*/)
{
}
总结就是说异步就用 boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred
同步就用boost::system::error_code
boost::system::error_code
error 我们用这个类型去接受在函数中产生的错误
如
socket.connect(
endpoint,
error);
如果连接失败,错误类型会保存到error中,比如连接主机失败可能会返回这样的错误
boost::asio::error::host_not_found;
通过if (error)检测到error后,抛出异常
throw boost::system::system_error(error);
需要注意的是,我们的error被 转化成 system_error了
显示错误很简单了,std::cout << e.what() 就哦啦。
大致的异常都是这个步骤进行的,然而还有一点在异步调用的时候,产生的异常error 的传递是个问题,因为异步会立刻返回,局部变量是会被销毁的,
boost::asio::placeholders::error,将会保存异常的状态,这样我们使用异步调用时如
socket::async_write_some的时候不用自己创建boost::system::error_co
error 了,直接使用
boost::asio::placeholders::error作为参数即可,
同理,我们sync_write_some需要返回读写数据的大小,令人开心的是boost::asio::placeholders::bytes_transferred直接作为参数就可以保存数据大小。
实例如下:
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));
}
参考手册上说的很明确, boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred就是为异步调用使用bind的时候设计的。
当然了boost::system::error_co
error还用有用的,同步调用的时候我们就用它作为参数
如:
boost::system::error_code
error;
size_t len
= socket.read_some(boost::asio::buffer(buf),
error);
同样在异步调用的回调handle中也用它作参数如
void
handle_write(const
boost::system::error_code&
/*error*/,
size_t
/*bytes_transferred*/)
{
}
总结就是说异步就用 boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred
同步就用boost::system::error_code
相关文章推荐
- C++实验2-两数差的绝对值
- JAVA学习 之 异常处理
- PHPStorm IDE 快捷键(MAC)
- js ==与===区别(两个等号与三个等号)(转载)
- 购物车多店铺列表数组处理
- python子进程模块subprocess详解与应用实例 之一
- Java顶尖程序员都看过的11本书
- 五猴分桃
- 关于Object.clone克隆方法的测试
- 各种排序算法的稳定性和时间复杂度小结
- mysqldump参数详细说明
- HTTPS的七个误解
- gvim配置文件for C/C++
- Handler、Message、MessageQueue随笔
- HLSL semantics
- jsp的内置对象
- Java day04 匿名对象
- Dom操作小实例----非常实用,将数据在两个select之间转移
- Java Web Session 登录实例
- Detours Express 3.0 笔记