1

FooTraitsclassにポリシーを提供する Visual Studio 2008 C++03 アプリケーションがありますFoo

struct FooTraits
{
    enum { FooVal = 1 };
};

template< typename traits >
class Foo
{
public:
    typedef typename traits::FooVal foo_val; // errors on this line

    void FooDo( UINT matrix[ foo_val ] ) { /*...*/ };
};

typedef Foo< FooTraits > Foot;

int main( int argc, char* argv[] )
{
    Foot f;
    UINT matrix[ Foot::foo_val ] = { /*...*/ };
    f.FooDo( matrix );
    return 0;
}

しかし、私は一連のコンパイラエラーをすべて取得しますtypedef:

error C2146: syntax error : missing ';' before identifier 'foo_val'
error C2838: 'FooVal' : illegal qualified name in member declaration
error C4430: missing type specifier - int assumed. Note: C++ does not support default-int

固定値を定義するポリシーを作成する正しい方法は何ですか?

4

3 に答える 3

2

FooTraits::FooValタイプではありません。これは、列挙型の可能な値の 1 つです。型ではないものを型定義することはできません。decltype(FooTraits::FooVal)、または列挙型に名前を付ける必要があります。

于 2012-05-18T14:36:48.223 に答える
1

によって導入された数値化された値enumは、それ自体は型ではありません。しかし、enumそれ自体はそうです。したがって、次のようになります。

enum Dummy { FooVal = 1 };

Dummyはタイプであり、 ではありませんFooVal。つまり、次のことができますtypedef Dummy

struct FooTraits
{
    enum Dummy { FooVal = 1 };
};

/* ... */

template< typename traits >
class Foo
{
public:
    typedef typename traits::Dummy dummy;
  };

しかし、それはタイプではないため、できませんtypedef FooVal。しようとtypedef FooValすることは、これをしようとするようなものです:

int foo = 42;
typedef FooBar foo;

…もちろん、意味はありません。

修正されたコードは次のとおりです。

struct FooTraits
{
    enum { FooVal = 1 };
};

template< typename traits >
class Foo
{
public:
    void FooDo( unsigned matrix[ traits::FooVal] ) { matrix;/*...*/ };
};

typedef Foo< FooTraits > Foot;

int main(  )
{
    Foot f;
    unsigned matrix[ FooTraits::FooVal ] = { /*...*/ };
    f.FooDo( matrix );
    return 0;
}
于 2012-05-18T14:40:04.993 に答える
0

型ではないため、 typedef はできませtraits::FooValん。

次の構文を使用します。

static const int foo_val = traits::FooVal;
于 2012-05-18T14:38:56.803 に答える