C 11 允许类内初始化:是什么推动了这一变化?
在 C 11 之前的时代,类内初始化是仅限于静态常量成员。此限制归因于需要避免多翻译单元场景中的链接器复杂性。
但是,随着 C 11 的引入,这些限制被放宽,允许非静态和非静态的类内初始化。 const 成员 (§12.6.2/8)。
虽然限制的最初推理仍然有效,但 C 11 实施了一个解决方案,将负担从链接器转移到编译器。编译器现在不再允许多个定义,而是处理初始化。
对于带有大括号或等于初始化器的非静态成员,初始化按照 8.5 执行。否则,如果它是变体成员 (9.5),则不会发生初始化。在所有其他情况下,执行默认初始化 (8.5)。
此外,用 constexpr 说明符标记的非常量静态成员现在可以在类中初始化 (9.4.2)。
此更改简化了代码维护并提供了更大的灵活性,但它增加了编程规则的一些复杂性。例如,如果一个成员指定了多个初始值设定项,则初始化值由所使用的构造函数确定。在调用默认构造函数的情况下,将使用类内初始值设定项。如果非默认构造函数指定了一个值,则类内初始值设定项将被忽略。
总体而言,这一更改反映了对改进开发人员人体工程学的日益重视,而不牺牲链接器可靠性。编译器现在承担更复杂的角色来促进这些功能,同时保持关注点的清晰分离。
以上是为什么 C 11 为非静态成员启用类内初始化?的详细内容。更多信息请关注PHP中文网其他相关文章!