簡體   English   中英

指向不是任何類成員的模板函數的指針

[英]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);

http://ideone.com/KyUjwP

在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;
}

http://ideone.com/Dh2eEN

在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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM