asio boost 异步错误处理_boost::asio::error的用法浅析
boost::asio::error的用法淺析
作者:轉載自:asio分享學習快樂更新時間:2009-8-2
一般而言我們創建用于接收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
總結
以上是生活随笔為你收集整理的asio boost 异步错误处理_boost::asio::error的用法浅析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 服务器安全之iptables iptab
- 下一篇: Shell 脚本案例实战 [4]