Boost::Asio::Error的用法淺析
睿豐德科技 專注RFID識別技術和條碼識別技術與管理軟件的集成項目。質量追溯系統、MES系統、金蝶與條碼系統對接、用友與條碼系統對接
一般而言我們創建用于接收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
RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成