我有Java背景,使用的是包,而不是名称空间。我习惯于将一起工作以形成完整对象的类放入包中,然后从该包中重用它们。但是现在我在用c++工作。
在c++中如何使用名称空间?您是为整个应用程序创建单个名称空间,还是为主要组件创建名称空间?如果是,如何从其他名称空间中的类创建对象?
我有Java背景,使用的是包,而不是名称空间。我习惯于将一起工作以形成完整对象的类放入包中,然后从该包中重用它们。但是现在我在用c++工作。
在c++中如何使用名称空间?您是为整个应用程序创建单个名称空间,还是为主要组件创建名称空间?如果是,如何从其他名称空间中的类创建对象?
当前回答
我所见过的大型c++项目很少使用一个以上的命名空间(例如boost库)。
实际上boost使用了大量的名称空间,通常boost的每个部分都有自己的内部工作空间,然后可能只将公共接口放在顶级名称空间boost中。
我个人认为,代码库越大,名称空间就越重要,即使在单个应用程序(或库)中也是如此。在工作中,我们将应用程序的每个模块放在自己的命名空间中。
我经常使用的命名空间的另一种用法(不是双关语)是匿名命名空间:
namespace {
const int CONSTANT = 42;
}
这基本等同于:
static const int CONSTANT = 42;
然而,使用匿名命名空间(而不是静态命名空间)是在c++中仅在当前编译单元中可见的代码和数据的推荐方式。
其他回答
注意,c++中的命名空间实际上只是一个名称空间。它们不提供Java包所提供的任何封装,因此您可能不会经常使用它们。
我使用c++命名空间的方式与我在c#、Perl等中使用的方式相同。它只是标准库内容、第三方内容和我自己的代码之间的符号语义分离。我会将自己的应用程序放在一个名称空间中,然后将可重用的库组件放在另一个名称空间中进行分离。
一般来说,如果我认为一段代码可能与其他库有函数或类型名称冲突,我会为它创建一个名称空间。它也有助于品牌代码,ala boost::。
为了避免赘述,Mark Ingram已经说了一个使用名称空间的小技巧:
避免在头文件中使用“using namespace”指令——这会为导入该头文件的程序的所有部分打开命名空间。在实现文件(*.cpp)中,这通常不是大问题——尽管我更喜欢在函数级别上使用“using namespace”指令。
我认为命名空间主要用于避免命名冲突,而不一定用于组织代码结构。我主要用头文件/文件结构来组织c++程序。
有时在较大的c++项目中使用名称空间来隐藏实现细节。
using指令的附加说明: 有些人喜欢只对单个元素使用“using”:
using std::cout;
using std::endl;
java和c++的另一个区别是,在c++中,名称空间层次结构不需要调整文件系统布局。因此,我倾向于将整个可重用库放在一个单独的命名空间中,并将库中的子系统放在子目录中:
#include "lib/module1.h"
#include "lib/module2.h"
lib::class1 *v = new lib::class1();
如果存在名称冲突的可能性,我只会将子系统放在嵌套的名称空间中。