首頁 > 後端開發 > C++ > 為什麼 C 模板類別中成員函數的明確特化會導致「非命名空間作用域」錯誤?

為什麼 C 模板類別中成員函數的明確特化會導致「非命名空間作用域」錯誤?

Mary-Kate Olsen
發布: 2024-12-04 06:15:17
原創
1009 人瀏覽過

Why Does Explicit Specialization of a Member Function in a C   Template Class Cause a

非命名空間範圍內的顯式專業化

查詢:

在 C模板類別中CConstraint,為什麼編譯器會在以下情況下產生錯誤「非命名空間範圍中的明確專業化」成員函數是明確特化的?

回應:

出現此問題的原因是 CConstraint 中的明確特化未在命名空間內聲明。根據 C 03 標準第 14.7.3/2 節,明確專業化必須駐留在模板的命名空間內,或對於成員模板,位於封閉類別或類別模板的命名空間內。

此外,C 03 部分14.7.3/3 限製成員函數的明確特化,除非包含類別本身是明確的

解決方案:

要解決此問題,一種方法是將verify()成員函數轉送到單獨命名空間中定義的專用自由函數,如下所示如下圖:

namespace detail {
    template <typename TL> void Verify(int, int[]) {}
    template <>            void Verify<int>(int, int[]) {}
}

template<typename T> class CConstraint {
    // ...
    template <typename TL> void Verify(int position, int constraints[]) {
        detail::Verify<TL>(position, constraints);
    }
};
登入後複製

以上是為什麼 C 模板類別中成員函數的明確特化會導致「非命名空間作用域」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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