所谓缺省参数,顾名思义,就是在声明函数的某个参数的时候为之指定一个默认值,在调用该函数的时候如果采用该默认值,你就无须指定该参数。
- 缺省值必须是常数或者是全局变量(静态区)
#include <iostream> using namespace std; void print(int x = 20) { cout << x << endl; } int main() { int a = 10; //不传参 print(); //传参 print(a); return 0; }
效果:
void print(int x = -1, int y = 1, int z = 2) { cout << x << endl; cout << y << endl; cout << z << endl; }
只能从右到左按顺序来给默认参数,必须连续,如果想要y给默认参数,则z必须先有默认参数,不能跳着来
void print(int x, int y = 1, int z = 2) { cout << x << endl; cout << y << endl; cout << z << endl; }
在栈扩容里面,需要判断是否需要扩容,这里不知道一开始栈里有没有元素,使用了一个三目操作符
初始化栈
//初始化栈 void StackInit(ST* ps, int capacity = 4) { assert(ps); ps->a = NULL; ps->top = 0;//栈顶还是0 ps->capacity = capacity; }
满了直接扩大2倍就可
注意:
c语言不支持缺省
定义和声明不能同时出现缺省参数
建议在函数的声明里面写缺省参数,因为一般看代码先看声明中参数类型
会出现这种bug
函数重载:是函数的一种特殊情况,C++允许在同一作用域中声明几个功能类似的同名函数,这些同名函数的形参列表(参数个数或类型或顺序)必须不同,常用来处理实现功能类似数据类型不同的问题
using namespace std; void print(int x, int y) { cout << x + y << endl; } void print(double x, double y) { cout << x + y << endl; } int main() { print(1, 2); print(1.22, 2.22); return 0; }
using namespace std; void print(double x) { cout << x << endl; } void print(double x, double y) { cout << x + y << endl; } int main() { print(1); print(1.22, 2.22); return 0; }
void print(char x, int y) { cout << x << endl; } void print(int y, char x) { cout << y << endl; }
本质上还是参数类型不同
注意
void f(int a) { } void f() { }
void f(int a = 0) { cout << 1 << endl; } void f(int a) { cout << 2 << endl; }
void f() { cout << 1 << endl; } void f(int a = 0) { cout << 2 << endl; }
编译器没法匹配是哪个
f()
函数,因为存在不知道匹配哪个的情况
先来回顾计算机从预编译到编译再到链接运行的过程是如何的
- 预处理:头文件展开,宏替换,条件编译,去掉注释
产生.i文件
- 编译:检查语法,符号汇总,生成汇编代码
产生.s文件
- 汇编:汇编代码转换成二进制机器码
产生.o文件
- 链接:将文件链接在一起
产生.out文件(linux下)
(只有声明没有定义会报链接错误)
void f();
从上面可以看出c语言对于函数编译完形成的符号比c++简单
c语言无法构成重载问题就出现在符号上,汇编过程中会给符号表函数符号,c语言仅仅给了f,而c++会对符号进行复杂的改善_Z + 函数名长度+函数名+参数首字母(这样保证重载函数的函数名一定不同),重载函数的符号不同,这样在调用的文件进行链接的时候,对于函数名进行查找,找到调用函数需要的地址,找到之后,进行,函数中指令和函数名地址什么的合并(符号表合并),不会出现不匹配的情况