嵌套模板gcc编译器4.1.2错误

问题描述 投票:0回答:3

我正在尝试创建一个模板类来将用户与数据类型隔离。 我更愿意使用适配器类,但需要更改函数签名,需要模板。

在下面的代码示例中(不是实际项目,只是说明问题的简化版本),而在主例程中,我可以使用 ob_traits 接口。 但是,当我尝试创建使用 ob_traits 作为基类的模板化 StructWrapper 时,出现错误,并且 gcc 无法识别创建的 IntAdapter 类。 这可以在 MSVC 8.0 上编译,但在 gcc 4.1.2 20070626(Red hat 4.1.2-14)上失败

首先有两个问题,你明白为什么编译失败并出现下面指定的错误吗?

第二,对于如何以更简单的方式实现这个概念有什么建议吗?

    #include <iostream>

    template <typename T >
    struct ob_traits
    {
        ob_traits( T& param ) { value = param; };
        T value;
    };

    struct GeneralStructure
    {
        int a;
        GeneralStructure(int param):a(param){}
    };

    struct DifferentStructure
    {
        GeneralStructure hidden;
        DifferentStructure( int param ):hidden(param){};
    }
    ;

    /*template< typename T > struct ob_traits
    {
    };
    */
    template<> struct ob_traits< GeneralStructure >
    {
        struct IntAdapter
        {
            IntAdapter( GeneralStructure& valueParam ):value(valueParam){}
            GeneralStructure value;
            int& getValue() { return value.a; };
        };
    };

    template<> struct ob_traits< DifferentStructure >
    {
        struct IntAdapter
        {
            IntAdapter( DifferentStructure& valueParam):value( valueParam ){}
            DifferentStructure value;
            int& getValue( ){ return value.hidden.a; };
        };
        void dump()
        {
            DifferentStructure testLocal(44);
            IntAdapter local( testLocal );
            std::cout << local.getValue()<<std::endl;
        }
    };

    template <typename T > struct StructWrapper:public ob_traits< T >
    {
        StructWrapper(){};
    /*main.cpp:60: error: 'IntAdapter' was not declared in this scope
    main.cpp:60: error: expected `;' before 'inner'
    main.cpp:60: error: 'inner' was not declared in this scope
    */
        void dumpOuter(const T& tempParam) { IntAdapter inner(tempParam); inner.dump(); };
    /*
    main.cpp: In member function 'void StructWrapper<T>::dumpOuterFailsAsWell(const T&)':
    main.cpp:66: error: expected `;' before 'inner'
    main.cpp:66: error: 'inner' was not declared in this scope
    */
        void dumpOuterFailsAsWell(const T& tempParam) { ob_traits<T>::IntAdapter inner(tempParam); inner.dump(); };
    };

    int main(int argc, char* argv[])
    {
        GeneralStructure dummyGeneral(22);
        ob_traits<struct GeneralStructure >::IntAdapter test(dummyGeneral);
        DifferentStructure dummyDifferent(33);
        ob_traits<struct DifferentStructure >::IntAdapter test2(dummyDifferent);
        std::cout << "GeneralStructure: "<<test.getValue()<<std::endl;
        std::cout << "DifferentStructure: "<<test2.getValue()<<std::endl;
        ob_traits<struct DifferentStructure > test3;
        test3.dump();
    std::cout << "Test Templated\n";
    return 0;
    }
c++ linux templates visual-c++
3个回答
2
投票

dumpOuter
失败,因为
IntAdapter
需要进行限定(如引用的问题中所示)。
dumpOuterFailsAsWell
失败,因为 GCC 会解析此代码,即使它不完整,因此它需要知道它是您所指的类型:

void dumpOuterWorks(const T& tempParam) 
{ 
   typename ob_traits<T>::IntAdapter inner(tempParam); 
   inner.dump(); 
}

如果没有

typename
,GCC 将假定 IntAdapter 是一个标识符,并期望您形成一个表达式而不是变量声明。

另请注意,您不必在方法体后面添加分号!


0
投票

StructWrapper
继承自主类模板(即最不专业的),它没有定义IntWrapper,因此不能在该类中使用。我不确定使用更专业的类型之一实例化
StructWrapper
是否允许它工作,或者它在编译类定义本身时是否失败。


0
投票

编译失败,因为 IntAdapter 只出现在专用模板中,因此在引用点不可见。

不清楚你会用它做什么?请说清楚情况。

© www.soinside.com 2019 - 2024. All rights reserved.