簡體   English   中英

標簽c ++ template class member struct成員語法初始化

[英]c++ Template class member struct initialization syntactic sugar

給定一個班級:

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM