给出一个课程:
template <typename T>
class foo
{
public:
struct bar
{
bar(T value) { m_foo = value; }
T m_foo;
...
}
...
}
和一个实例:
foo<int> myfoo;
是否可以创建bar
的实例而无需再次指定myfoo
类型:
myfoo::bar mybar;
// foo<int>::bar mybar;
当我尝试这个时,我得到一个错误对(VS 2015):
&#39; myfoo&#39;:不是类或命名空间名称
&#39; bar&#39;:未找到标识符
更新 这是我想要实现的更详细的例子:
template <typename T, typename T2, typename T3>
class MyClass
{
public:
struct MyClassCreateParameters
{
MyClassCreateParameters( T t, T2 t2, T3 t3 )
:
T1Param( t ), T2Param( t2 ), T3Param( t3 ) { }
T T1Param;
T2 T2Param;
T3 T3Param;
};
MyClass( const MyClassCreateParameters& params )
:
m_t1( params.T1Param ),
m_t2( params.T2Param ),
m_t3( params.T3Param ) { }
private:
const T m_t1;
const T2 m_t2;
const T3 m_t3;
};
int main()
{
MyClass< int, char, char* >* myclass;
myclass = new MyClass< int, char, char* >(
myclass::MyClassCreateParameters( 1, 'A', "abc" ) );
return 0;
}
答案 0 :(得分:3)
使用C ++ 11,您应该可以:
decltype(myfoo)::bar mybar;
答案 1 :(得分:1)
从表面上看,我会使用typedef:
template <typename T1, typename T2, typename T3>
class MyClassTemplate
{
public:
struct Params { /* ... */ };
MyClassTemplate(Params);
// ...
};
using MyClass = MyClassTemplate<int, char, char*>;
MyClass x(MyClass::Params(a, b, c));
但是,您也可以使用转发构造函数模板赋予您的类模板:
template <typename T1, typename T2, typename T3>
class MyClassTemplate
{
private:
struct Params { /* ... */ };
MyClassTemplate(Params);
public:
template <typename ...Args>
MyClassTemplate(Args ...args) : MyClassTemplate(Params(args...)) {}
// ...
};
MyClassTemplate<int, char, char*> x(a, b, c);