С++ 0x decltype и оператор разрешения области
С таким классом, как Foo:
struct Foo { static const int i = 9; };
Я обнаружил, что GCC 4.5 отклонит следующие
Foo f;
int x = decltype(f)::i;
Он будет работать, если я использую промежуточный typedef, например:
typedef decltype(f) ftype;
int x = ftype::i;
но я предпочитаю, чтобы пространство имен было чистым. Я думал, что приоритет может быть проблемой, поэтому я также пробовал скобки, но не повезло. Это невозможно, как представлено, или есть ли синтаксис, который может мне помочь?
Ответы
Ответ 1
Действительно, С++ 0x говорит decltype(f)::i
. GCC только этого пока не поддерживает. Вы можете работать с шаблоном идентификации
template<typename T> struct identity { typedef T type; };
int x = identity<decltype(f)>::type::i;
identity
является частью пространства имен boost::mpl
.