• Boost::Asio::Error的用法浅析


    一般而言我们创建用于接收error的类型大多声明如下: 
    boost::system::error_code error 我们用这个类型去接受在函数中产生的错误


    socket.connectendpointerror);
    如果连接失败,错误类型会保存到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_code了,直接使用boost::asio::placeholders::error作为参数即可,
    同理,我们async_write_some需要返回读写数据的大小,令人开心的是boost::asio::placeholders::bytes_transferred直接作为参数就可以保存数据大小。
    实例如下:


    boost::asio::async_write(socket_boost::asio::buffer(message_),
    boost::bind(&tcp_connection::handle_writeshared_from_this(),boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred));

    参考手册上说的很明确, boost::asio::placeholders::error,boost::asio::placeholders::bytes_transferred就是为异步调用使用bind的时候设计的。
    当然了boost::system::error_code还是有用的,同步调用的时候我们就用它作为参数
    如:
    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

     

     转自:https://www.cnblogs.com/lzjsky/archive/2011/05/12/2044460.html
  • 相关阅读:
    SDUT 2128 树结构练习——排序二叉树的中序遍历
    SDUT 2137 数据结构实验之求二叉树后序遍历和层次遍历
    SDUT 3341 数据结构实验之二叉树二:遍历二叉树
    总结:串和数组的学习
    SDUT 3347 数据结构实验之数组三:快速转置
    SDUT 3348 数据结构实验之数组二:稀疏矩阵
    SDUT 1500 Message Flood
    SDUT 2463 学密码学一定得学程序
    SDUT 2125 数据结构实验之串二:字符串匹配
    mybatis学习(七)(choose的学习)
  • 原文地址:https://www.cnblogs.com/liushui-sky/p/13645702.html
Copyright © 2020-2023  润新知