Visual C++ 模板类成员结构初始化语法糖

visual c++ Template class member struct initialization syntactic sugar

本文关键字:结构 初始化 语法 成员 C++ Visual      更新时间:2023-10-16

给定一个类:

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):

'

myfoo':不是类或命名空间名称

"bar":找不到标识符

更新以下是我想要实现的目标的更详细示例:

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

使用 C++11,您应该能够执行以下操作:

decltype(myfoo)::bar mybar;

从表面上看,我会使用 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);