2016-04-29 27 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を<のuint32_t(サンプル:: *)(ダブル)>'それはメンバ関数であると? – 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; 
} 
関連する問題