Следующий код довольно тривиален, и я ожидал, что он должен скомпилироваться.
struct A
{
struct B
{
int i = 0;
};
B b;
A(const B& _b = B())
: b(_b)
{}
};
Я тестировал этот код с g++ версии 4.7.2, 4.8.1, clang++ 3.2 и 3.3. Помимо того факта, что g++ 4.7.2 segfaults на этот код (http://gcc.gnu.org/bugzilla/show_bug.cgi?id=57770), другие проверенные компиляторы предоставляют сообщения об ошибках, которые не объясняют многое.
g++ 4.8.1:
test.cpp: In constructor ‘constexpr A::B::B()’:
test.cpp:3:12: error: constructor required before non-static data member for ‘A::B::i’ has been parsed
struct B
^
test.cpp: At global scope:
test.cpp:11:23: note: synthesized method ‘constexpr A::B::B()’ first required here
A(const B& _b = B())
^
clang++ 3.2 и 3.3:
test.cpp:11:21: error: defaulted default constructor of 'B' cannot be used by non-static data member initializer which appears before end of class definition
A(const B& _b = B())
^
Возможность компиляции этого кода возможна и, похоже, не имеет значения. Существует два варианта:
struct B
{
int i = 0;
B(){} // using B()=default; works only for clang++
};
или
struct B
{
int i;
B() : i(0) {} // classic c++98 initialization
};
Является ли этот код действительно неправильным или неверны компиляторы?