命名空间
前言
在了解“using namespace std; ”究竟何意?之前要先了解namespace
namespace应用环境
在C/C++中,变量、函数和类都是大量存在的,它们的名称都将存在于全局变量中,可能导致很多冲突。使用命名空间的目的是对标识符的名称进行本地化,以免命名冲突或名字污染,namespace关键字的出现就是针对这种问题的。
#include <stdio.h>
#include <stdlib.h>
int rand = 10;
//C语言没办法解决类似的命名冲突问题,所以C++提出了namespace来解读
int main()
{
printf("%d", rand);
return 0;
}
//编译后报错: error c2365: "rand": 重定义:以前的定义是“函数”
namespace定义
在C++中,namespace是一种用于组织代码的机制,它可以帮助避免命名冲突并提供更为清晰的代码结构。namespace定义了一块独立的命名空间,其中可以包含各种程序元素,如类型、函数、变量和类等。在命名空间中的所有元素都通过命名空间的名称进行限定,这样可以避免多个源文件或库中同名元素之间的冲突。
namespace的语法如下:
namespace NamespaceName {
// Namespace body: declarations and definitions
//命名空间主体 :声明 和 定义
}
定义命名空间,需要用到namespace关键字,后面跟命名空间的名字,然后接一对{}即可,{}中即为命名空间的成员。
几种命名方法和代码举例
- 正常命名空间类型:
namespace Fibonacci //此处的Fibonacci为NamespaceName,因人而异
{
// 命名空间中可以定义变量/函数/类型
int rand = 10;
int Add(int left, int right)
{
return left + right;
}