совпадать с порядком декларации членов?
В чём сысл делать не так как в C99, где порядок не имеет значения. В этом-то и польза подобного синтаксиса — не надо вспоминать, как там что определено. Ты явно задаёшь имя члена, снижая шанс ошибиться.
Потому что порядок конструирования
Если ты меняешь порядок в списке инициализации, это не значит, что меняется порядок конструирования. Важно, когда инициализация имеет зависимые друг от друга члены данных
В C99 нет конструкторов. В C++ порядок инициализации членов класса явно прописан, designated initializers можно было задизайнить 4мя способами * как сейчас * с неявным вызовом дефолтных конструкторов при несовпадении поряда * переделать очерёдности инициализации (тут куча проблем) * неявно инициировать в правильном порядке (что может быть очень неожиданно для пользователей) Выбрали самый простой и надёжный способ
То есть неявно инициализировать в правильном порядке в списке инициализаторов конструктора - это ОК, а неявно инициализировать в правильном порядке в initializer_list (это видимо не он, но тут давайте этот термин употребим) - это НЕ, ЗАПУТАЕМ ПОЛЬЗОВАТЕЛЕЙ ЯЗЫКА! Ну да. Логично.
Хорошо. Но зачем тогда все эти жёсткие ограничения на aggregate type: отсутствие конструкторов, в том числе дефолтных и удалённых?
чтобы не уложнять правила по выборку перегруженного метода
то что раньше сделали плохо, не значит что надо делать плохо и сейчас
У меня есть друг он говорит "пусть безобразно, зато единообразно"
Обсуждают сегодня