• 欢迎浏览“String me = Creater\忠实的资深Linux玩家;”,请文明浏览,理性发言,有侵犯你的权益请邮件我(creater@vip.qq.com).
  • 把任何的失败都当作一次尝试,不要自卑;把所有的成功都想成是一种幸运,不要自傲。
  •    4年前 (2014-04-14)  boost.asio 评论关闭  37 
    文章评分 0 次,平均分 0.0

    一般而言我们创建用于接收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。

     

    除特别注明外,本站所有文章均为String me = "Creater\忠实的资深Linux玩家";原创,转载请注明出处来自http://unix8.net/home.php/3284.html

    关于
    切换注册

    登录

    忘记密码 ?

    切换登录

    注册

    扫一扫二维码分享