绪论
从本章开始我们正式进入到C++的内容,对此如果没有学习过C语言的建议先将C语言系统的学习一遍后再来(已经更新完在专栏就能看到)。
话不多说安全带系好,发车啦(建议电脑观看)。
思维导图:
要XMind思维导图的话可以私信哈
目录
1.C++关键字
2.命名空间(namespace)
2.1命名空间
2.1.1 域:
2.1.2命名空间域的展开:
3.C++的输入和输出
4.缺省参数(默认参数)
5.函数重载
6.引用
6.1引用的定义:
6.2使用场景:
6.3常引用问题
6.4引用的总结:
7.关键字auto
8.范围for
9.内联函数
10.指针空值nullptr
1.C++关键字
知识点:
C++的关键字的含义和C语言中一样都是有特殊意义的名称,我们在创建变量的时候不能使用相同的名。
细节:
下面是C++中的63个关键字,我们不需要去死记,通过不断学习自然就记住了。
2.命名空间(namespace)
2.1命名空间
在C语言中会有命名冲突的问题,在c++中为了避免一个项目中不同程序员写的代码(或者程序员写的变量名和库函数的函数名)发生命名的冲突,就推出了命名空间这个概念来解决命名冲突这个问题。对此命名空间内可以定义变量、函数、结构体、再嵌套一个命名空间 ......
知识点:
2.1.1 域:
域一般分为:全局域、局部域、作用域(C语言已讲)、命名空间域、类域
细节:
下面通过代码来展示不同的域:
namespace ZYK { int a = -1;//在命名空间的变量,就是命名空间域 } int a = 1;//全局域 int main() { int a = 0;//在局部变量中就是局部域,和局部变量非常类型 return 0; }
对于域的使用优先级一般是:局部域 , 全局域
若加上了 域作用限定符 : “ :: ” 的话则会更先执行限定符指定的空间,域作用限定符的使用是:左边是命名空间名 ::右边则是要执行的变量名
当没有指定/展开命名空间域时在搜索变量时并不会自动去命名空间域内去搜索,命名空间域时DIY名称的。
对于全局域来说他的域名就是空(即当不输入域名时就代表要访问全局域)
2.1.2命名空间域的展开:
知识点:
他的意思和他的名字一样:
就是把一个命名空间进行了展开,直接展开到了全局域中,所以要注意的是如果全局域有和命名空间域相同的变量名时就会报错(命名不明确),对此我们反思到,在一般情况下我们加上这个命名空间就是为了防止这种情况,所以我们一般看情况展开(在一多人合作的项目中我们不能进行展开、而在日常自己练习和单独完成的项目我们可以适当的进行展开)
基本语法:
using + namesapce + 命名空间名
来展开对应的命名空间
附:当同时定义了多个相同名的命名空间时,此时会将这几个相同的命名空间进行合并,同样也不能有相同的变量名
下面通过练习来实践:
练习:
1. 在有局部域和全局域以及命名空间域的同时,先执行全局域再执行命名空间域最后访问局部域:
#define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> namespace ZYK { int a = -1;//在命名空间的变量,就是命名空间域 } int a = 1; int main() { int a = 0; printf("%d\n", ::a); printf("%d\n", ZYK::a); printf("%d\n", a); return 0; }
2. 对于嵌套的来说其大体使用方法一样(嵌套的指定即可):
这里就不过多的去叙述了,直接通过代码来展示:
3. 展开命名空间:
namespace ZYK { int a = -1; } using namespace ZYK; int main() { int a = 0; printf("%d\n", ::a); printf("%d\n", ZYK::a); printf("%d\n", a); return 0; }
3.C++的输入和输出
知识点:
std是C++的标准库的命名空间的域名,C++的标准库的定义和实现都放在了这个命名空间内(和C语言中的 stdio.h 这个头文件有点类似 在std中包含的则是C++标准库的函数)
细节:
上面我们知道了c++中有一个命名空间名std ,他其中包含了许多函数,所以为了使用一个命名空间内的函数。我们就有两种方法也就是域作用限定符来指定/展开命名空间域
但是要注意的是并不是展开/指定了就能使用该函数了,同样要先用#define包含头文件,再通过std来间接的访问函数。所以说这两样东西缺一不可。
练习:
1. cout、endl
一般来说cout 和 endl 是同时使用的,
cout:(可以大概的理解成我们程序的那个黑框框)可以将 << (流插入运算符) 流进来的进行打印
endl:其实可以大概的看成 \n
cout 相较于printf来说:他可以连续一行插入多个数据,并且可以自动识别类型
附:而cin流提取运算符(类似scanf)
练习使用方法如下:
第一种方法:
一个正常使用该cout、endl时我们需要加上的条件:
头文件:#include<iostream> 、 展开std命名空间
优点:可以能更加便捷的使用
缺点:同样直接把一个命名空间打开是一个非常危险的举动
第二种方法:
此时我们并没有去展开一个命名空间,通过指定访问的方法来实现
但是:不要忘记了头文件#include<iostream>
优点:没有了展开命名空间的风险
缺点:若要多次使用则会些冗杂
第三种方法(也是比较推荐的方法):
这种方法是将所要用到的进行单独的展开,我们可以在常用的对应进行展开,而不常用的直接使用第二种方法
头文件 #include<iostream>(不能省略)
附:cout的自动识别的展示、以及因为自动识别而导致的精度丢失的问题(缺点)
附:在c++中可以写c的语法,因c++是兼容c的(所以我们printf和cout混着使用)
4.缺省参数(默认参数)
知识点:
在函数的形参部分加上一个初始值(缺省参数),当你没传参数时就会用缺省参数,如果你传了参数那就正常的使用传来进的参数值。
细节:
当我们同时有多个形参时,对于缺省参数的使用情况大概和单个时的情况差不多但是要注意的是:
传参时是从左往右依次传上去的(所以从左往右的算传几个算几个,若没传就用缺省参数)
并且不可以跳跃的来传递实参
缺省参数必须是从右往左的确立的(即若一半是正常形参一半是缺省形参时,此时正常形参必须在缺省形参的左边,这种形参别称为半缺省型,反之全缺省)
当我们分源管理时我们应该在哪里写这个缺省参数呢:
缺省参数应该只写在函数的声明处(因为怕出现声明和定义不同的问题),而不是写在定义处
练习:
1. 缺省参数的具体应用:
2. 传多个参数时要注意的点
a.不能跳跃传参
b.从左往右传参的
c.半缺省:(缺省参数必须从右往左,因为我们传参是从左往右的)
5.函数重载
知识点:
在C语言中我们无法同时使用多个相同函数名但类型不同的函数,所以c++就对这方面进行了优化,让同名当不同参数类型的函数可以正常使用
细节:
对于函数重载时的参数一般分为三类:
1、类型不同
2、类型的数量不同
3、类型的顺序不同
4、总结来说就是:两个同名的函数其函数类型不能对应相等即可
而对于为什么C语言不能对相同的函数名的函数进行函数调用而c++却可以:
是因为在编译链接阶段 创建的符号表中命名的函数命有区别 ,C语言是直接把函数名命名当成符号表,而c++在生成符号表时的命名规则并不是直接用函数名而是有不同的命名规则
因此对于C语言来说当出现两个相同函数名时,就会导致链接时冲突、
而对于c++来说就不会出现冲突因为类型的不同所以函数命名就会不同(在gcc环境下的函数名的命名规则是:_Z3funii 其中_Z是固定的 + 3 是函数名的字符个数 + 函数名 + 函数的类型 ii : 两个整形)