Следующий код ведет себя иначе с или без пользовательского конструктора копирования в GCC 8.0.1:
#include <cassert>
struct S {
int i;
int *p;
S() : i(0), p(&i) {}
// S(const S &s) : i(s.i), p(&i) {} // #1
// S(const S &s) : i(s.i), p(s.p) {} // #2
// S(const S &s) = delete; // #3
};
S make_S() {return S{};}
int main()
{
S s = make_S();
assert(s.p == &s.i);
}
С любым из комментариев созданных пользователем конструкторов копий (даже С# 2, который выполняет простую мелкую копию), это утверждение не сработает, что означает гарантированное копирование elision работает как ожидалось.
Однако, без какого-либо пользовательского конструктора копирования, утверждение не выполняется, что означает, что объект s
в main
не построен по умолчанию. Почему это происходит? Здесь не гарантируется копирование?