本文主要是介绍boost库asio详解6——boost::asio::error的用法浅析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1. 概述
一般而言我们创建用于接收error的类型大多声明如下:- boost::system::error_code error
- socket.connect(endpoint, error);
- boost::asio::error::host_not_found;
- throw boost::system::system_error(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直接作为参数就可以保存数据大小。
实例如下:
- 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
3. 同步调用
当然了boost::system::error_code error还用有用的,同步调用的时候我们就用它作为参数。如:- boost::system::error_code error;
- size_t len = socket.read_some(boost::asio::buffer(buf), error);
- void handle_write(const boost::system::error_code& /*error*/,
- size_t /*bytes_transferred*/)
- {
- }
4. 总结
异步就用 boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred同步就用 boost::system::error_code
这篇关于boost库asio详解6——boost::asio::error的用法浅析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!