boost :: asio :: async_read绑定编译错误

时间:2011-06-28 21:18:43

标签: c++ boost bind boost-asio

我无法弄清楚为什么会收到此错误:

/usr/local/include/boost/asio/impl/read.hpp: In member function ‘void boost::asio::detail::read_op<AsyncReadStream, boost::asio::mutable_buffers_1, CompletionCondition, ReadHandler>::operator()(const boost::system::error_code&, size_t, int) [with AsyncReadStream = boost::asio::basic_stream_socket<boost::asio::ip::tcp, boost::asio::stream_socket_service<boost::asio::ip::tcp> >, CompletionCondition = boost::asio::detail::transfer_at_least_t, ReadHandler = boost::function<void ()(long unsigned int)>]’:
/usr/local/include/boost/asio/impl/read.hpp:263:   instantiated from ‘void boost::asio::async_read(AsyncReadStream&, const MutableBufferSequence&, CompletionCondition, ReadHandler) [with AsyncReadStream = boost::asio::basic_stream_socket<boost::asio::ip::tcp, boost::asio::stream_socket_service<boost::asio::ip::tcp> >, MutableBufferSequence = boost::asio::mutable_buffers_1, CompletionCondition = boost::asio::detail::transfer_at_least_t, ReadHandler = boost::function<void ()(long unsigned int)>]’
src/communicator/protocol/Command.cc:34:   instantiated from here
/usr/local/include/boost/asio/impl/read.hpp:215: error: no match for call to ‘(boost::function<void ()(long unsigned int)>) (const boost::system::error_code&, const long unsigned int&)’
/usr/local/include/boost/function/function_template.hpp:1007: note: candidates are: typename boost::function1<R, T1>::result_type boost::function1<R, T1>::operator()(T0) const [with R = void, T0 = long unsigned int]
make: *** [src/communicator/protocol/Command.o] Error 1

我的班级: Command.hh

namespace communicator {                                              
  namespace protocol {                                                
    namespace in {                                                    
      class Command : public boost::enable_shared_from_this<Command> {
      public:                                                         
        ~Command();                                                   

        typedef boost::shared_ptr<Command>      pointer;              

        void got_newline();                                           

      protected:                                                      
        Command(tcp::socket& socket, structure::Client& client) :     
          m_socket(socket), m_client(client)  {};

        void endParsing();

        tcp::socket&            m_socket;                             

        structure::Client&      m_client;                             
        char                    m_newline[2];                          
      private:                             

      };                                                              
    }
}   

Command.cc:

namespace   communicator {
    namespace protocol {
    namespace in {

      void Command::endParsing()  {
        boost::function<void()> cb = boost::bind(&Command::got_newline,
                                          shared_from_this());
        boost::asio::async_read(m_socket,
                                boost::asio::buffer(m_newline, 2),
                                boost::asio::transfer_at_least(2),
**ERROR POINTING THIS LINE**                                    cb);
      }

      void Command::got_newline()  {
        if (m_newline[0] == '\r' && m_newline[1] == '\n') {
           std::cout << "End" << std::endl;
          }
      }

    }
  }
}

检查代码块上的“**错误指向此行**”,这是它有问题的地方......不知道为什么,一次又一次地打破我的头......

感谢您的帮助

为了清晰起见,我删除了一些代码,如果您有任何疑问,请不要犹豫

2 个答案:

答案 0 :(得分:3)

您的完成处理程序签名不正确,请考虑此示例

#include <boost/asio.hpp>

#include <boost/function.hpp>
#include <boost/bind.hpp>

void
foo()
{

}

int
main()
{
    boost::asio::io_service io_service;
    boost::asio::ip::tcp::socket socket( io_service );

    char buf[2];

    // this compiles file
    boost::asio::async_read(
            socket,
            boost::asio::buffer(buf),
            boost::asio::transfer_at_least(2),
            boost::bind( &foo )
            );

    // this does not
    boost::function<void()> cb = boost::bind( &foo );
    boost::asio::async_read(
            socket,
            boost::asio::buffer(buf),
            boost::asio::transfer_at_least(2),
            cb
            );

}

boost::bind非常聪明,不会将errorbytes_transferred参数传递给绑定的函数指针。 Asio库的作者有detailed blog post关于使用与库的绑定。值得一读。

答案 1 :(得分:1)

async_ *操作需要不同的回调函数签名:

void handler(
  const boost::system::error_code& error, // Result of operation.
  std::size_t bytes_transferred           // Number of bytes read.
); 

请深入了解一些如何编写和调用此类回调处理程序的示例文档。