C++命名空间和缺省参数的概念

命名空间

  • 在C/C++中,变量、函数和后面要学到的类都是大量存在的,这些变量、函数和类的名称将都存在于全局作用域中,可能会导致很多冲突。使用命名空间的目的是对标识符的名称进行本地化,以避免命名冲突或名字污染,namespace 关键字的出现就是针对这种问题的。
  • 1 、命名空间定义
    • 定义命名空间,需要使用到namespace关键字,后面跟命名空间的名字,然后接一对{}即可,{}中即为命名空间的成员。
    //1. 普通的命名空间
    namespace N1 // N1为命名空间的名称
    {
	    // 命名空间中的内容,既可以定义变量,也可以定义函数
	    int a;
	    int Add(int left, int right)
	    {
	   		 return left + right;
	    }
    }

//2. 命名空间可以嵌套

namespace N2
{
	int a;
	int b;
	int Add(int left, int right)
	{
		return left + right;
	}
	namespace N3
	{
		int c;
		int d;
		int Sub(int left, int right)
		{
			return left - right;
		}
	}
}
//3. 同一个工程中允许存在多个相同名称的命名空间
// 编译器最后会合成同一个命名空间中。
namespace N1
{
	int Mul(int left, int right)
	{
		return left * right;
	}
}
  • 注意:一个命名空间就定义了一个新的作用域,命名空间中的所有内容都局限于该命名空间中
  • 2 、命名空间使用
  • 命名空间中成员该如何使用呢?比如:
namespace N
{
	int a = 10;
	int b = 20;
	
	int Add(int left, int right)
	{
		return left + right;
	}
	
	int Sub(int left, int right)
	{
		return left - right;
	}
}

int main()
{
	printf("%d\n", a); // 该语句编译出错,无法识别a
	return 0;
}
  • 命名空间的使用有三种方式:

    • 加命名空间名称及作用域限定符

      int main()
      {
      	printf("%d\n", N::a);
      	return 0;
      }
      
  • 使用using将命名空间中成员引入

    using N::b;
    int main()
    {
    	printf("%d\n", N::a);
    	printf("%d\n", b);
    	return 0;
    }
    
  • 使用using namespace 命名空间名称引入

using namespce N;
int main()
{
	printf("%d\n", N::a);
	printf("%d\n", b);
	Add(10, 20);
	return 0;
}

缺省参数

  • 缺省参数概念:缺省参数是声明或定义函数时为函数的参数指定一个默认值。在调用该函数时,如果没有指定实参则采用该默认
    值,否则使用指定的实参。
void TestFunc(int a = 0)
{
	cout<<a<<endl;
}

int main()
{
	TestFunc(); // 没有传参时,使用参数的默认值
	TestFunc(10); // 传参时,使用指定的实参
}
  • 缺省参数分类
    • 1、全缺省参数
void TestFunc(int a = 10, int b = 20, int c = 30)
{
	cout<<"a = "<<a<<endl;
	cout<<"b = "<<b<<endl;
	cout<<"c = "<<c<<endl;
}
 - 2、半缺省参数
void TestFunc(int a, int b = 10, int c = 20)
{
	cout<<"a = "<<a<<endl;
	cout<<"b = "<<b<<endl;
	cout<<"c = "<<c<<endl;
}
  • 注意:
  • 半缺省参数必须从右往左依次来提供,不能间隔着给出
  • 缺省参数不能同时在函数声明和定义中出现,只能二者择其一,也就是说必须在函数调用之前将默认值的信息通知编译系统。由于编译是从上到下的逐行执行的,如果在函数调用之前未得到默认值信息,在编译到函数调用时,就会认为参数个数与形参个数不匹配而报错。如果在声明函数已对形参给出了默认值,而在定义函数时又对形参给出默认值,有的编译系统会给出“重复指定默认值”的报错信息,有的编译器对此不报错,甚至允许在声明和定义时给出的默认值不同,此时编译系统以先遇到的为准。由于函数声明在函数定义之前,因此以声明时给出的默认值为准,而忽略定义函数时给出的默认值。
  • 缺省值必须是常量或者全局变量
  • 一个函数不能做重载函数,有作为有默认参数的函数。因为当调用函数时如果少写一个参数,系统就无法判定是重载函数还是利用默认参数的函数,出现二义性,系统无法执行。
  • C语言不支持

猜你喜欢

转载自blog.csdn.net/qq_40421919/article/details/83020733
今日推荐