[英]Pointer to template function which is NOT member of any class
我想有指向模板函数的指针,该函数具有2个类型为T
参数。
template <typename T>
typedef bool( * f )( T, T );
template <typename T>
bool mniejsze (T pierwszy , T drugi){
if( pierwszy < drugi)
return true;
return false;
}
template <typename T>
bool wieksze (T pierwszy, T drugi){
if( pierwszy > drugi )
return true;
return false;
}
但是我得到:
error: template declaration of 'typedef'|
编辑:然后我想传递该指针:是正确的方法吗?
template <typename T>
T minmax(T a[], int n,bool &f){
return f(a[0],a[1]);
}
在C ++ 11中,您可以使用别名:
template<typename T>
using f = bool( *)( T, T );
用法:
f<int> f1 = wieksze;
f1( 3, 4);
在C ++ 03中,存在一个工作区:
template<typename T>
struct f {
typedef bool( *type)( T, T );
};
用法:
f<int>::type f1 = mniejsze<int>;
f<int>::type f2 = mniejsze<int>;
f1( 3, 4);
template<typename T>
T minmax(T a[], int n, typename f<T>::type fp ){
if ( fp( a[0], a[1])) return 1;
return -1;
}
int main() {
// your code goes here
f<int>::type f1 = wieksze<int>;
bool b = f1( 3, 4);
int a[] = { 3, 4};
std::cout << minmax<int>( a, 0, f1);
return 0;
}
在C ++ 11中,您可以执行以下操作:
template<class T>
using f = bool(*)(T, T);
并使用:
f<int> fp = wieksze;
接下来呢?
template <typename T>
struct FNPTR {
typedef bool (*f)( T, T );
};
放置一个虚拟包装结构,并在以后使用FNPTR :: f? 例如,
FNPTR::f = mniejsze<char>;
这应该工作!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.