首页 > 后端开发 > C++ > 为什么 C 11 中的类内初始化器仅限于 `=` 和 `{}`?

为什么 C 11 中的类内初始化器仅限于 `=` 和 `{}`?

Susan Sarandon
发布: 2024-12-19 01:50:09
原创
663 人浏览过

Why are In-Class Initializers in C  11 Restricted to `=` and `{}`?

类内初始化器的语法限制

在 C 11 中,类内初始化器只能使用等号 (=) 或大花号大括号 {} 为成员赋值。为什么会出现这种情况?

歧义缓解

大括号语法强制对代码进行明确的解释。考虑这个例子:

class Example {
    struct Inner;
    int member;

    int conflicting(Inner); // Function declaration or member initialization?
};
登录后复制

如果没有大括号限制,代码片段可能会不明确。第一行可以解释为函数声明或使用括号的成员初始化。

class Example {
    struct Inner;
    int member;

    int conflicting{Inner}; // Clearly a member initialization
};
登录后复制

大括号阐明冲突是初始化为 Inner 值的成员。

额外的清晰度

使用大括号还可以通过分隔成员声明来提供额外的清晰度和初始化。这可以增强可读性并减少误解的可能性。

以上是为什么 C 11 中的类内初始化器仅限于 `=` 和 `{}`?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板