c ++模板类成员struct初始化语法糖

时间:2017-01-05 23:32:29

标签: c++ visual-c++

给出一个课程:

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;
}

2 个答案:

答案 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);