本文将介绍C++中的命名空间、输入输出操作以及缺省参数的概念和使用方法。通过本文的学习,读者将了解到命名空间的定义、特性和使用方法,以及C++中的输入输出操作和缺省参数的概念及使用方式。
在C/C++中,变量、函数和类都是大量存在的,这些变量、函数和类的名称将都存在于全局作用域中,可能会导致很多冲突。因此,c++引入了命名空间,有效的解决这个问题。命名空间的作用是对标识符的名称进行本地化,避免命名的冲突。
语法:使用namespace关键字,后面跟命名空间的名字,然后接一对{},{}中即为命名空间的成员。
namespace yxx
{
int a;
int b;
int Add(int x, int y)
{
return x + y;
}
namespace yx
{
int c;
int d;
int Sub(int a, int b)
{
return a - b;
}
}
}
namespace yxx
{
int num;
}
加命名空间名称及作用域限定符
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;
}
在C语言中我们使用的是printf和scanf来进行输入和输出的操作,c++又是怎么样的呢?
include<iostream>
// std是C++标准库的命名空间名,C++将标准库的定义实现都放到这个命名空间中
using namespace std;
int main()
{
cout << "Hello world!!!" << endl;
return 0;
}
#include
using namespace std;
int main()
{
int a;
double b;
char c;
// 可以自动识别变量的类型
cin >> a;
cin >> b >> c;
cout << a <<" "<< b <<" "<< c << endl;
return 0;
}
声明或定义函数时为函数的参数指定一个缺省值。在调用该函数时,如果没有指定实参则采用该形参的缺省值,否则使用指定的实参。
void Func(int a = 0)
{
cout<<a<<endl;
}
int main()
{
Func(); // 没有传参时,使用参数的默认值
Func(10); // 传参时,使用指定的实参
return 0;
}
void Func(int a = 10, int b = 20, int c = 30)
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
void Func(int a, int b = 10, int c = 20)
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
半缺省参数必须从右往左依次来给出,不能间隔着给
缺省参数不能在函数声明和定义中同时出现
//a.h
void Func(int a = 10);
// a.cpp
void Func(int a = 20)
{}
// 如果声明与定义位置同时出现,恰巧两个位置提供的值不同,那编译器就无法确定到底该
用那个缺省值。
缺省值必须是常量或者全局变量
C语言不支持(编译器不支持)
本文详细介绍了C++中命名空间的定义、特性和使用方法,包括命名空间的定义语法、特性和三种使用方式。此外,还介绍了C++中的输入输出操作,包括使用cout进行标准输出和使用cin进行标准输入。最后,文章还介绍了缺省参数的概念及全缺省参数和半缺省参数的使用方法,以及一些细节点的注意事项。通过本文的学习,读者可以更好地理解和应用C++中的命名空间、输入输出操作和缺省参数。