我正在尝试创建一个模板类来将用户与数据类型隔离。 我更愿意使用适配器类,但需要更改函数签名,需要模板。
在下面的代码示例中(不是实际项目,只是说明问题的简化版本),而在主例程中,我可以使用 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;
}
dumpOuter
失败,因为 IntAdapter
需要进行限定(如引用的问题中所示)。 dumpOuterFailsAsWell
失败,因为 GCC 会解析此代码,即使它不完整,因此它需要知道它是您所指的类型:
void dumpOuterWorks(const T& tempParam)
{
typename ob_traits<T>::IntAdapter inner(tempParam);
inner.dump();
}
如果没有
typename
,GCC 将假定 IntAdapter 是一个标识符,并期望您形成一个表达式而不是变量声明。
另请注意,您不必在方法体后面添加分号!
StructWrapper
继承自主类模板(即最不专业的),它没有定义IntWrapper,因此不能在该类中使用。我不确定使用更专业的类型之一实例化 StructWrapper
是否允许它工作,或者它在编译类定义本身时是否失败。
编译失败,因为 IntAdapter 只出现在专用模板中,因此在引用点不可见。
不清楚你会用它做什么?请说清楚情况。