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?