f soll eine Klasse sein - Sie haben eine Funktion.
Siehe unten:
// Class acts like a function - also known as functor.
template<typename T, int a, int b>
class f
{
int operator()(T v)
{
return v*a-b; // just do something for example
}
};
template<typename T, int a, int b, template<typename,int,int> class func>
class C
{
int f()
{
return func<T,a,b>(3);
}
};
int main()
{
C<float,3,2, f> c;
}
... Und die angepasste Version, wenn Sie benötigen Port Legacy-Code (Passt sich die Funktion einer Klasse-Vorlage):
#include <iostream>
template<typename T, int a, int b>
int f(T v)
{
std::cout << "Called" << std::endl;
return v*a-b; // just do something for example
}
template<typename T, int a, int b, template<typename,int,int> class func>
struct C
{
int f()
{
return func<T,a,b>(3);
}
};
template <class T, int a, int b>
struct FuncAdapt
{
T x_;
template <class U>
FuncAdapt(U x)
: x_(x)
{}
operator int() const
{
return f<T,a,b>(x_);
}
};
int main()
{
C<float,3,2, FuncAdapt > c;
c.f();
}
Was genau versuchen Sie zu erreichen? – nijansen
mein Compiler stürzte während der Ausführung dieses Codes ab. – Saksham
@nijansen ist nicht MSVS2010 stabil ?? – Saksham