C++,私有函数真的需要在头文件中吗?
我一直认为头文件是一种描述类的"公共接口",在这种情况下,最好将私有字段和函数保留在cpp文件中。
我知道头中需要有私有字段,这样其他类才能知道一个类的实例将消耗多少内存,但当我要编写一个私有帮助器函数时,我突然想到这个函数可以成为静态的,在这种情况下,它根本不需要是类的一部分,它可以很容易地成为类定义的.cpp文件中的常规函数。
然后我想到,所有私有函数可能会重写为静态函数,方法是接受指向类字段的指针/引用,而不是期望在类中定义。
这将消除在头文件中声明任何私有函数的需要。
我确实喜欢遵循约定,所以现在我想问一下,非静态私有函数应该在头文件中是不是在C++中被认为是既定的约定?静态函数或静态常量怎么办?
编辑:我将放入一些代码来解释我的意思:
.h文件:
#ifndef SOME_CLASS_H
#define SOME_CLASS_H
class SomeClass
{
private:
int x;
public:
void combineWithX(int y);
};
#endif
.cpp文件
#include "SomeClass.h"
void someHelper(int* x)
{
*x = (*x) + 1;
}
void SomeClass::combineWithX(int y)
{
someHelper(&x);
x += y;
}
请注意,cpp文件中的someHelper(int* x)
在本质上引用了私有成员x,但不是直接引用,因此不需要出现在头中。我想知道这种事情是不是被认为是‘糟糕的风格’
解决方案
我同意需要在头文件中公开实现详细信息是一个问题;这会干扰接口和实现的分离。
如果.cpp
文件中的私有帮助器函数需要访问私有成员变量,则将这些函数移动为自由函数(我假设这就是您所说的"静态")将不起作用。
您可能有兴趣查看pImpl idiom(more)
相关文章