假设我有一个这样的课程Foo
:
foo.h :
namespace mine {
class Foo {
Widget widget_;
public:
void bar();
// some other members...
};
} // namespace mine
foo.cpp :
#include "foo.h"
namespace mine {
void Foo::bar() {
// Some very long code
}
} // namespace mine
出于可读性原因,我想将bar()
拆分为多个函数。函数本身对Foo
(或Foo::bar()
以外的任何其他实体)没有任何特殊含义,仅用于拆分bar()
,因此根据this的讨论我将在源文件中执行以下操作:
foo.cpp (已重构):
#include "foo.h"
// anonymous namespace to put all helper functions
namespace {
void computeResult() { ... }
void modifyWidget(Widget& w) { ... }
void doThis() { ... }
void doThat(Widget& w) {
// ...
modifyWidget(w);
}
} // <anonymous> namespace
// actual methods are defined here
namespace mine {
void Foo::bar() {
::doThis();
::doThat(widget_);
::computeResult();
}
} // namespace mine
因此,我在源文件中定义了一个匿名命名空间,以便定义帮助程序功能,这样我就具有静态链接,并且从源文件外部看不到帮助程序功能。在我看来奇怪的一件事是,类方法依赖于不属于类的函数,但是如果这是一个问题,那么我们将无法使用标准库。
Foo::widget_
传递到修改它的某些独立功能(doThat()
)时是否存在问题?我在这里假设在静态链接帮助器函数的狭窄上下文中,调用者/被调用者知道他们在做什么。答案 0 :(得分:0)