Deducción de plantilla de C ++ mientras llama a una función de plantilla
-
26-10-2019 - |
Pregunta
FastDelegate
se refiere a http://www.codeproject.com/kb/cpp/fastdelegate.aspx, pero no creo que esté relacionado.
Tengo código como seguir y recibí un error.
#include <FastDelegate.h>
using namespace fastdelegate;
template <typename T>
T Getter() {}
template <typename T>
void Setter(T) {}
template <typename T>
class Prop
{
public:
typedef FastDelegate0<T> Getter;
typedef FastDelegate1<T> Setter;
Prop(Getter getter, Setter setter) :
m_Getter(getter), m_Setter(setter)
{
}
private:
Getter m_Getter;
Setter m_Setter;
};
template <typename T>
inline Prop<T>* MakeProp(FastDelegate0<T> getter, FastDelegate1<T> setter)
{
return new Prop<T>(getter, setter);
}
static int Target = 0;
int main()
{
FastDelegate0<int> fdGetter(Getter<int>);
Prop<int>* c = MakeProp(fdGetter, Setter<int>);
// ^^^^ error: no matching function for call to 'MakeProp'
}
Si se cambia el main()
a:
int main()
{
FastDelegate0<int> fdGetter(Getter<int>);
FastDelegate1<int> fdSetter(Setter<int>);
Prop<int>* c = MakeProp(fdGetter, fdSetter); // It works.
}
o:
int main()
{
FastDelegate0<int> fdGetter(Getter<int>);
Prop<int>* c = MakeProp<int>(fdGetter, Setter<int>); // It works, too.
}
Pienso, MakeProp()
debería obtener el T
de fdgetter (que es int
, que llamado el Contructor de FastDelegate1<int>
automáticamente. Pero no lo hizo. ¿Por qué?
PD: Me gustaría guardar el Getter y Setter en Prop
, cualquier sugerencia para este enfoque es bienvenida. Tal vez sea malo copiar la instancia de FastDelegate* durante los argumentos de aprobación en la función.
Solución
Has probado
Prop<int>* c = MakeProp(FastDelegate0<int>(Getter<int>), FastDelegate1<int>(Setter<int>));
?
Setter<int>
no se puede convertir a FastDelegate1<T>
!
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow