2016-04-29 4 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; 
} 
Смежные вопросы