0

如何为模板类中的模板函数创建函数回调。这是我到目前为止所拥有的:

template <typename SocketType> 
class NettyPBSslSerializer {
    ...
    template <typename Handler>
    void async_read(google::protobuf::Message *pbmess,Handler handler ) {
            void (NettyPBSslSerializer<SocketType>::*f1)(
                    const boost::system::error_code&,std::size_t offset,google::protobuf::Message *pbmess,boost::tuple<Handler>)
                    =&NettyPBSslSerializer<SocketType>::async_read_varint <Handler> ;

            boost::asio::async_read (socket_,
                                     boost::asio::buffer(&read_buffer_.at(0), 9),
                                     boost::asio::transfer_at_least(1),
                                     boost::bind(f1,this,boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred, pbmess,boost::make_tuple(handler) )
                                    );
    }
    template <typename Handler>
    void async_read_varint(const boost::system::error_code& e, std::size_t offset,google::protobuf::Message *pbmessp, boost::tuple<Handler> handler) {
    }

    ....
    SocketType socket_; 

}

我使用 g++ 得到以下错误

  nettypbserializer.hpp|186| error: expected primary-expression before '>' token
  nettypbserializer.hpp|186| error: expected primary-expression before ';' token

第 186 行是

=&NettyPBSslSerializer<SocketType>::async_read_varint <Handler> ;
4

1 回答 1

1

您不能将指针指向(成员)函数模板,因为它还不存在。一种解决方案是将Handler类型参数移动到NettyPBSslSerializer(so as NettyPBSslSerializer<SocketType, HandlerType>),然后绑定&NettyPBSslSerializer::async_read_varint...

编辑:

这实际上很容易。您不能使用指向成员函数模板的指针,但可以构建一个闭包,该函数模板将在其中使用正确的类型进行实例化并将结果传递给boost::async. 这是一个概念实现

#include <iostream>

namespace boost {
    template <typename Stream, typename Handler>
    void async_read(Stream p_Stream, Handler p_Handler)
    {
        p_Handler();
    }
}

template <typename SocketType>  
class NettyPBSslSerializer { 
    SocketType m_Socket;

        template <typename Handler> 
        void async_read_varint(Handler handler) {
                handler();
        } 
public:
        template <typename Handler> 
    void async_read(Handler handler) {
        boost::async_read(m_Socket, [&]() -> void {
            this->async_read_varint(handler);
        });
        } 

    NettyPBSslSerializer(SocketType const & p_Socket) : m_Socket(p_Socket) {}
};

void a_handler()
{
    std::cout << "a_handler called" << std::endl;
}

int main()
{
    NettyPBSslSerializer<int> tTmp(42); 

        tTmp.async_read(a_handler);
}
于 2012-09-10T17:47:31.837 回答