目录
1. 什么是C++
C++(c plus plus)是一种计算机高级程序设计语言,由C语言扩展升级而产生 ,最早于1979年由本贾尼·斯特劳斯特卢普在AT&T贝尔工作室研发。它完善了C语言的许多缺陷,并且引入了面向对象的程序设计思想,包括面向对象的四个特性:封装,继承,多态,抽象
2. C++的标准库
标准的 C++ 由三个重要部分组成:
核心语言,提供了所有构件块,包括变量、数据类型和常量,等等。
C++ 标准库,提供了大量的函数,用于操作文件、字符串等。,提供了大量的方法,用于操作数据结构等。
这三个部分包含了C++这门语言的核心,我们后面的内容就主要围绕上面三个部分展开。
3. C++的发展历史
4. C++的关键字
5. C++的输入与输出
C++的标准输入与输出函数是cin与cout,分别对应C语言的scanf与printf。但是相较于C语言,C++输入输出并不需要指定占位符,如:%d,%c等。
#include<iostream>
using namespace std;//展开命名空间
int main()
{
cout << "hello world" << endl;
//endl相当于换行符
cout << "hello world" << '\n';
cout << 'a' << endl;
int b = 1;
cout << b << endl;
cout << &b << endl;
return 0;
}
在C++中使用cin与cout,需要包含头文件iostream以及std标准命名空间。
6. 命名空间
6.1. 域作用限定符
作用域限定符::,其作用是通知编译器应从作用域限定符左侧的名字所示的作用域中寻找右侧那个名字,即指定访问哪个名字空间的哪个成员。当左侧为空时,默认访问的就是全局域。
#include<iostream>
int a = 1;
void func()
{
int a = 0;
printf("%d\n", a);
printf("%d\n", ::a);
}
int main()
{
func();
return 0;
}
我们知道C语言遵循局部优先的规则,即当局部变量与全局变量冲突时,默认使用局部变量。而在C++中,我们可以通过域作用限定符来访问全局变量。
6.2. 为什么要存在命名空间
命名空间(namespace)是C++语言特别重要的特性,当第三方供应商提供的库时为了避免与其他供应商或者用户定义的名字相冲突(命名空间污染),常常将库的内容放置在自己独立的命名空间中。C++标准库也定义了相应命名空间std,用户在使用标准库时必须通过域作用域运算符::,或者使用using关键词来简化命名空间中名字的使用。
比如如下代码:
#include<iostream>
#include<stdlib.h>
int rand = 1;
int main()
{
printf("%d\n", rand);
return 0;
}
当我们定义rand变量时,就会与stdlib库中的rand函数出现命名冲突,这在C语言中只能通过修改变量名称来解决。但是在C++中,我们可以就可以使用命名空间来解决。
6.3. 命名空间的定义
定义命名空间,需要使用到namespace关键字,后面跟命名空间的名字,然后接一对{}即可,{}中即为命名空间的成员。
#include<iostream>
#include<stdlib.h>
namespace GGbond
{
int rand = 1;
}
int main()
{
printf("%d\n", GGbond::rand);
//使用域作用限定符,指定作用域
return 0;
}
6.4. 命名空间的使用
在我们定义完命名空间之后,我们可以通过三种方式访问命名空间。
6.4.1. 域限定符访问
这我们在前面已经实验演示过,现在我们来演示一下访问C++标准命名空间。(cout,endl等常用函数都被定义在C++标准命名空间std中)。
#include<iostream>
int main()
{
std::cout << "hello GGbond" << std::endl;
return 0;
}
如果未指定命名空间,编译器将报错。
6.4.2. using 部分展开
在我们书写代码时,可能会频繁调用某个函数,这是我们可以使用using部分展开,来简化代码。使用方式为using 命名空间名称:: 成员。
#include<iostream>
int main()
{
std::cout << "hello GGbond" << std::endl;
std::cout << "hello GGbond" << std::endl;
std::cout << "hello GGbond" << std::endl;
//频繁调用cout,endl
return 0;
}
#include<iostream>
using std::cout;
using std::endl;
int main()
{
cout << "hello GGbond" << endl;
cout << "hello GGbond" << endl;
cout << "hello GGbond" << endl;
return 0;
}
6.4.3. using namespcae全部展开
除了部分展开,自然也有全局展开。其格式为using namespace 命名空间名。
#include<iostream>
using namespace std;
int main()
{
cout << "hello GGbond" << endl;
cout << "hello GGbond" << endl;
cout << "hello GGbond" << endl;
return 0;
}
但这种方式在真正的项目实战中,并不推荐使用。因为这可能造成不必要的冲突。但是我们平时练习为了方便,可以全部展开
6.5. 命名空间的嵌套
命名空间的使用与循环,选择语句一样是支持嵌套使用的。
#include<iostream>
using namespace std;
namespace GGbond1
{
int a = 1;
namespace GGbond2//嵌套
{
int Add(int a, int b)
{
return a + b;
}
}
}
int main()
{
cout << GGbond1::a << endl;
//访问通过限定符依次访问
cout << GGbond1::GGbond2::Add(1, 2) << endl;
return 0;
}
6.6. 命名空间的合并
在同一个工程中我们可以定义多个名称相同的命名空间,在编译时命名空间会自动合并。
namespace GGbond
{
int a = 1;
}
namespace GGbond
{
int b = 1;
}
//编译时会自动合并
7. 缺省参数
7.1. 缺省参数的使用
缺省参数是声明或定义函数时为函数的参数指定一个缺省值。在调用该函数时,如果没有指定实参则采用该形参的缺省值,否则使用指定的实参。
void func(int a = 0)
{
cout << a << endl;
}
int main()
{
func(); // 没有传参时,使用参数的默认值,输出0
func(1); // 传参时,使用指定的实参,输出1
return 0;
}
7.2. 缺省参数的分类
根据其缺省参数的个数,我们我可以将缺省参数分为全缺省与半缺省。
7.2.1. 全缺省
每一个参数都有缺省值。
#include<iostream>
using namespace std;
void func(int a = 0,int b = 1,int c = 2)
{
cout <<"a=" << a << endl;
cout << "b = " << b << endl;
cout << "c = " << c << endl;
}
int main()
{
func();//不穿参数
func(10,20);//半传参数
func(10, 20, 30);//全传
return 0;
}
7.2.2. 半缺省
只有一部分参数有缺省值,并且半缺省参数必须从右往左依次来给出,不能间隔着给。
#include<iostream>
using namespace std;
void func(int a ,int b=1,int c=2)
{
cout <<"a = " << a << endl;
cout << "b = " << b << endl;
cout << "c = " << c << endl;
}
int main()
{
func(10,20);//半传参数
cout << endl;
func(10, 20, 30);//全传
return 0;
}
7.2.3. 注意
在使用缺省参数时,我们也要知道一些注意事项:
- 传参时不能间隔传参。
void func(int a ,int b=1,int c=2)
{
cout <<"a = " << a << endl;
cout << "b = " << b << endl;
cout << "c = " << c << endl;
}
func(,10,20)//error
2.缺省参数不能在函数声明和定义中同时出现
//test.h
void Func(int a = 10);//声明
// test.cpp
void Func(int a = 20)//定义
{}
- 缺省值必须是常量或者全局变量。
- C语言不支持(编译器不支持)。