首頁 > 後端開發 > C++ > 為什麼 C 語言中禁止函數模板的部分特化?

為什麼 C 語言中禁止函數模板的部分特化?

Susan Sarandon
發布: 2024-12-06 01:50:11
原創
780 人瀏覽過

Why are Partial Specializations of Function Templates Prohibited in C  ?

函數模板的部分特化:為什麼不呢?

眾所周知,C 語言規範禁止函數模板的部分特化。這項決定讓許多開發人員感到困惑,他們質疑其有用性和基本原理。

由於疏忽,語言規範禁止函數模板的部分專業化。部分專業化提供的靈活性可以透過替代技術來實現,例如將函數定義為類別的靜態成員。

例如,考慮以下程式碼:

template<typename T, typename U> void f() {}   //allowed!
template<> void f<int, char>()            {}   //allowed!
template<typename T> void f<char, T>()    {}   //not allowed!
template<typename T> void f<T, int>()     {}   //not allowed!
登入後複製

而不允許f 的部分特化,我們可以透過將函數定義為類別的靜態成員來實現類似的效果:

void say( char const s[] ) { std::cout << s << std::endl; }

namespace detail {
    template< class T, class U >
    struct F {
        static void impl() { say( "1. primary template" ); }
    };

    template<>
    struct F<int, char> {
        static void impl() { say( "2. <int, char> explicit specialization" ); }
    };

    template< class T >
    struct F< char, T > {
        static void impl() { say( "3. <char, T> partial specialization" ); }
    };

    template< class T >
    struct F< T, int > {
        static void impl() { say( "4. <T, int> partial specialization" ); }
    };
}  // namespace detail

template< class T, class U >
void f() { detail::F<T, U>::impl(); }    

int main() {
    f<char const*, double>();       // 1
    f<int, char>();                 // 2
    f<char, double>();              // 3
    f<double, int>();               // 4
}
登入後複製

此程式碼的行為類似函數模板的部分特化,提供一種機制來定義特定參數組合的專門實作。

以上是為什麼 C 語言中禁止函數模板的部分特化?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板