2016-04-29 116 views
2

我想传递重载函数指针,如下面的示例代码中所示。C++重载函数指针模糊

class Sample 
{ 
    uint32_t method(char* input1, double input2); 
    uint32_t method(double input1); 
} 

template<class T, class... Args) 
void processInput(T &&t, Args&&... a) 
{ 
    std::packaged_task<uint32_t(Args...)> task(std::bind(t, a...)); 
    // other processing 
} 

// Caller invokes the below API 
Sample* obj = new Sample(); 
processInput(static_cast<uint32_t(*)(double)>(&Sample::method), &*obj, 2.0f); 

但是这段代码不能编译。它一直抱怨它无法确定哪个重载函数实例是有意的。我提到的几个例子:

C++ overloaded method pointer

http://en.cppreference.com/w/cpp/language/static_cast

可在指出别人的帮助是怎么回事错在这里?

+3

Shoudln't'的static_cast <双(*)(双)>'是'的static_cast ',因为它是一个成员函数? – NathanOliver

+1

@pree修复你的拼写错误(缺少';',''''而不是'>')。该函数也不返回'double'。 – LogicStuff

+0

就是这样!我真的不明白static_cast在函数重载中的实现,并且做错了!谢谢@NathanOliver&LogicStuff。 – pree

回答

4

修复错别字后,主要问题是您试图将成员函数指针强制转换为函数指针。

也就是说,下面是非法的:

static_cast<uint32_t(*)(double)>(&Sample::method) 
error: invalid static_cast from type 
‘uint32_t (Sample::*)(double) {aka unsigned int (Sample::*)(double)}’ 
to type 
‘uint32_t (*)(double) {aka unsigned int (*)(double)}’ 

一个成员函数指针的语法

ReturnT(ClassT::*)(ArgTs); 

所以你的施法必须是:

static_cast<uint32_t(Sample::*)(double)>(&Sample::method) 

实施例:

#include <iostream> 
#include <functional> 

struct Sample 
{ 
    uint32_t method(char* input1, double input2) { return 0; } 
    uint32_t method(double input1) { return 0; } 
}; 

template<class T, class... Args> 
void processInput(T &&t, Args&&... a) 
{ 
    auto task = std::bind(t, a...); 
    (void)task; 
} 

int main() 
{ 
    Sample* obj = new Sample(); 
    processInput(static_cast<uint32_t(Sample::*)(double)>(&Sample::method), obj, 2.0f); 

    return 0; 
}