Рассмотрим следующий код:
template <typename T> using VoidT = void;
class A {
public:
using TEST = int;
};
class C {
public:
using DIFFERENT = int;
};
template <typename T, typename Enable = void>
class B {
public:
B() = delete;
};
template <typename T>
class B<T, VoidT<typename T::TEST>> {
public:
B() = default;
};
template <typename T>
class B<T, VoidT<typename T::DIFFERENT>> {
public:
B() = default;
};
int main() {
B<A> a;
B<C> b;
return 0;
}
Используя g ++ - 4.8.5, компиляция этого кода дает мне следующее сообщение об ошибке:
~/test/compile_test> g++ -std=c++11 test.cpp
test.cpp:31:7: error: redefinition of ‘class B<T, void>’
test.cpp:24:7: error: previous definition of ‘class B<T, void>’
Однако, когда я компилирую, используя g ++ - 8.3 (например, в ideone), код компилируется, и различные специализации обрабатываются правильно. Была ли это ошибка в GCC, которая была исправлена, или я как-то вызываю неопределенное поведение (и, следовательно, разница в поведении компилятора является спорным вопросом - он не определен)?