什么是命名空间
命名空间是ANSIC++引入的可以由用户命名的作用域。使用命名空间的目的是对标识符的名称进行本地化,以避免命名冲突或名字污染。它可作为附加信息来区分不同库中相同名称的函数、类、变量等。使用了命名空间即定义了上下文。本质上,命名空间就是定义了一个范围。
有了命名空间的概念,标识符就被限制在特定的范围呢,不会引起命名冲突。最典型的例子就是std命名空间,C++标准库中所有标识符都包含在该命名空间中。
命名空间的作用
C++中命名空间的作用类似于操作系统中的目录和文件的关系,由于文件很多,不便管理,而且容易重名,于是设立若干子目录,把文件放到不同的子目录中,不同子目录中的文件可以同名,而调用文件时应指出文件路径。
命名空间的作用是建立一些互相分隔的作用域,把一些全局实体分隔开来,以免产生名字冲突
定义命名空间
定义命名空间需要使用关键字namespace关键字,后面跟命名空间的名字,然后接一对{ }即可,{ }中为命名空间的成员。为了调用命名空间的函数或变量需要在前面加上命名空间的名称。一个命名空间就定义了一个新的作用域,命名空间中的所有内容都局限于该命名空间中。
命名空间使用的三种方式
- 加命名空间名称以及作用域限定符(::)
- 使用using将命名空间中的成员引入
- 使用using namespace命名空间的引入
#include <iostream>
// 第一个命名空间
namespace first_space //first_space为命名空间的名称
{
void func(){
std:: cout << "Inside first_space" << std::endl;
}
}
// 第二个命名空间
namespace second_space
{
void func(){
std:: cout << "Inside second_space" << std::endl;
}
}
// **同一个工程中允许存在多个相同名称的命名空间**
// 编译器最后会合成同一个命名空间中。
namespace first_space
{
std:: cout << "mwj" << std::endl;
}
int main ()
{
// 调用第一个命名空间中的函数
first_space::func();
// 调用第二个命名空间中的函数
second_space::func();
return 0;
}
using指令
使用 using namespace 指令,这样在使用命名空间时就可以不用在前面加上命名空间的名称。这个指令会告诉编译器,后续的代码将使用指定的命名空间中的名称。using 指令引入的名称遵循正常的范围规则。名称从使用 using 指令开始是可见的,直到该范围结束。此时,在范围以外定义的同名实体是隐藏的。比如:
#include <iostream>
using namespace std;
// 第一个命名空间
namespace first_space
{
void func(){
cout << "Inside first_space" << endl;
}
}
// 第二个命名空间
namespace second_space
{
void func(){
cout << "Inside second_space" << endl;
}
}
using namespace first_space;
int main ()
{
// 调用第一个命名空间中的函数
func();
return 0;
}
#include <iostream>
using std::cout;
namespace N
{
int a=0;int b=1;
}
using N::b;//引入N作用域下的成员b
int main()
{
cout<<N::a<<" ";//::域限定符
cout<<b;
return 0;
}
不连续的命名空间
命名空间可以定义在几个不同的部分中,因此命名空间是由几个单独定义的部分组成的。一个命名空间的各个组成部分可以分散在多个文件中。
所以,如果命名空间中的某个组成部分需要请求定义在另一个文件中的名称,则仍然需要声明该名称。
嵌套的命名空间
#include <iostream>
using namespace std;
// 第一个命名空间
namespace first_space{
void func(){
cout << "Inside first_space" << endl;
}
// 第二个命名空间
namespace second_space{
void func(){
cout << "Inside second_space" << endl;
}
}
}
int main ()
{
//在一个命名空间的作用域下调用第二个命名空间中的函数
first_space::second_space ::func();
return 0;
}