Typ dedukcji, gdy używany jest wskaźnik funkcji członka jako argument szablonu

Kiedy chcę mieć funkcję członka jako argument szablonu, czy istnieje sposób na jej szablonowanie bez podawaniaCaller rodzaj?

<code>struct Foo
{
    template <typename Caller, void (Caller::*Func)(int)>
    void call(Caller * c) { (c->*Func)(6); }
};

struct Bar
{
    void start() 
    {
        Foo f;
        f.call<Bar, &Bar::printNumber>(this);
               ^^^^  
    }

    void printNumber(int i) { std::cout << i; }
};

int main ()
{
    Bar b;
    b.start();
    return 0;
}
</code>

kiedy próbuję

<code>template <void (Caller::*Func)(int), typename Caller>
void call(Caller * c) { (c->*Func)(6); }
</code>

i nazwij to jak

<code>f.call<&Bar::printNumber>(this);
</code>

staje sięCaller is not class... błąd.

Czy istnieje sposób, aby pozwolić kompilatorowi wywnioskować typ dzwoniącego?

questionAnswers(1)

yourAnswerToTheQuestion