缺省函数
缺省参数概念
缺省参数是声明或定义函数时为函数的参数指定一个默认值。在调用该函数时,如果没有指定实参则采用该 默认值,否则使用指定的实参。
缺省函数其实就是给函数参数装备胎—没错甚至专门强调了备胎,属于是了属于是.
如何给我们的函数参数装备胎呢.
如下图的Add函数.
上面的Add函数就安好了备胎,及当我们在不给Add传参数时,就让n1和n2的值为备胎值也就是n1=1,n2=2;
但是我们就只想给n1传值呢?那就想第二个传参一样只给个2就好这样,n1=2了
但是我们只想给n1传值呢?答案是不可以🤪.
但是我们只想给一个或不是全部函数参数安备胎要怎么办呢?
答案是:可以但是只能从右往左安备胎而且中间不能有间隔.
这样安备胎的我们是不可以传空值的,而且对应没有安备胎的值是不可以不传参的.
必须注意的是,在安备胎的函数上我们的函数声明这么办呢?
不能同时在一个函数的函数声明和定义上安备胎
如下图
所以我们安备胎的时候要选是在声明处还是定义处.
函数重载
函数重载:是函数的一种特殊情况,C++允许在同一作用域中声明几个功能类似的同名函数,这些同名函数的 **形参列表(参数个数 或 类型 或 顺序)**必须不同,常用来处理实现功能类似数据类型不同的问题
注意:上面的不同的是形参列表而返回类型的不同并不可以构成函数重载.
下面的Add函数都可以构成重载函数
//不同形参类型如下 int Add(int left, int right) { return left+right; } double Add(double left, double right) { return left+right; } long Add(long left, long right) { return left+right; } // //不同顺序如下 void f(int i,double d) { return; } void f(double d,int i) { return; } // int main() { Add(10, 20); Add(10.0, 20.0); Add(10L, 20L);//l后缀是表示为long return 0; }
还有不同类型参数的不同放置顺序也是可以构成重载函数.
那么为什么函数重载在C++可以发生呢?
函数重载的原因
此知识需要看程序的编译(预处理操作)
我们知道我们的在编译的编译阶段(没错,是编译的编译阶段),会有语法检查等一系列操作,如果发现有同名函数就会发生报错并停止后续操作.
而我们的C++对函数的在编译阶段的命名用了新的格式.
如下图:
上图是void f(int a,double b)和void f(double b ,int a)这两个函数的命名.
其中
_Z是前缀所有cpp都有这个前缀
1是函数名长度
f是函数名
i,d是我们函数参数类型的首字母(i是int; d是double)
从上面可以看出我们C++在给命名的时候并没有考虑到返回类型所以返回类型不同并不可以实现重构函数.
而我们的C语言是直接拿函数名当做汇编时的命名.
如下图:
而我们的编译器在连接的时候会把符号表里名字相同的进行链接操作,所以C语言不能进行函数重载操作.