为什么C++方法有时在类中定义
Why are C++ methods sometimes defined inside classes?
我经常在C++中遇到大型非模板类,其中简单方法直接在头文件的类体中定义,而不是在实现文件中单独定义。例如:
class Foo {
int getBar() const { return bar; }
...
};
为什么要这样做?似乎有缺点。实现没有像它应该的那样隐藏,代码可读性较差,如果类的头文件包含在许多不同的地方,编译器的负担也会增加。
我的猜测是,人们希望将这些函数内联到其他模块中,这样可以显著提高性能。然而,我听说较新的编译器可以在链接时跨模块进行内联(以及其他过程间优化)。这种链接时间优化的支持范围有多广,它实际上是否使这些定义变得不必要?这些定义还有其他充分的理由吗?
C++标准规定,类定义中定义的方法默认为inline
。这会为getter和setter等简单函数带来明显的性能提升。链接时跨模块优化更难,尽管有些编译器可以做到。
通常除了更容易和节省时间之外没有其他原因。它还节省了实现文件中的一些混乱,同时占用了头文件中相同数量的行。如果只限于getter和setter之类的东西,那么可读性就很差了。
您回答了自己的问题,它们确实是内联方法。
使用它们的原因是性能。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 部分定义/别名模板模板参数
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- #为""定义宏;静态";针对不同的上下文
- 如何确保C++函数在定义之前声明(如override关键字)
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在命名空间中定义函数还是限定函数
- 此代码是否违反一个定义规则
- 编译C++时未定义的引用
- 不同翻译单元中不可重载的非内联函数定义
- 为什么在定义函数之前先声明它
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 在类定义之后定义一个私有方法
- 使用用户定义函数的字符串反转
- 用户定义函数中的指针和输入
- vscode g++链路故障:体系结构x86_64的未定义符号
- 如何定义一个纯抽象基类