当前位置:首页 » 《随便一记》 » 正文

c++篇---缺省参数

4 人参与  2023年05月02日 18:09  分类 : 《随便一记》  评论

点击全文阅读


文章目录

一、缺省参数概念二、缺省参数实例三、缺省参数声明和定义四、全缺省和半缺省


一、缺省参数概念

缺省参数

在调用该函数时,如果实参没有指定传内容,那么在函数中用形参时,就采用为函数参数指定的这个缺省值
但是如果在调用该函数时,实参指定传了内容,那么函数在使用时使用指定的形参
缺省参数是一个默认参数,在函数形参中给它赋一个值,此时也就叫做缺省参数

二、缺省参数实例

实例1

#include<iostream>using namespace std;//缺省参数void fun(int a = 0){cout << a << endl;}int main(){fun();//没有为fun函数传参,fun采用的是它的缺省值fun(10);//调用fun函数时,为其指定传参,fun函数使用的是指定传的参数return 0;}

在这里插入图片描述

实例2

#include<iostream>using namespace std;void fun1(int a = 10, int b = 20, int c = 30){cout << "a:"<<a << endl;cout <<"b:"<< b << endl;cout << "c:"<<c << endl;cout << endl;}int main(){fun1();//调用fun1函数时,一个实参都没传,fun1函数采用的是形参的缺省值fun1(1);//调用fun1函数时,传了一个实参,c++调用函数时,实参传参,形参接收是从左边开始传的//实参传给形参是从左边开始传的从左往右,此时传了一个,那么fun1在使用是除了使用指定的实参之外,//其余的还是采用形参的缺省值fun1(1, 2);//调用fun1函数时,传了两个实参,由于参数传参是从左往右,那么fun1函数在使用形参时前两个形参使用指定实参,//后一个形参采用形参的缺省值fun1(1, 2, 3);//调用fun1函数时,传了三个实参,fun1函数在使用形参时,使用的是指定实参值return 0;}

在这里插入图片描述

实例3
模拟栈插入数据

struct stack{int* a;int size;int capacity;};void stackInit(struct stack* pst){pst->a = (int*)malloc(sizeof(int) * pst->capacity);if (pst->a == NULL){perror("malloc fail\n");return;}pst->size = 0;pst->capacity = 4;}void stackPush(struct stack* pst, int x){if (pst->size == pst->capacity){int* tmp = (int*)malloc(sizeof(int) * (pst->capacity) * 2);if (tmp == NULL){perror("malloc fail\n");return;}pst->a = tmp;pst->capacity *= 2;}pst->a[pst->size++] = x;}

但是这样可以发现每次往栈中插入数据时都会检查是否需要扩容 而真的当空间不够需要扩容时,扩容又会导致额外消耗
在对栈初始化时可以先开空间,至于开多大,可以初始给默认为4
但是如果此时我们已经知道需要插入多少数据,数据量又超过了初始给开的空间,此时序需要扩容造成消耗,所以在初始化时可以给缺省参数,缺省值默认为4,如果知道要插入多少数据,
那么在调用这个函数时,实参传给定知道插入的数据个数,此时初始化开的空间也就是实参给定的值 这样可以避免因空间不够开空间带来的消耗
但是此时会问,既然都知道要插入多少数据了直接用静态栈不好吗,静态栈虽然好但是不是每次都能知道要插入多少数据
所以在初始化时给缺省值应对不同场景

初始化栈给缺省参数

void stackInit(struct stack* pst,int defaultcapacity = 4){pst->a = (int*)malloc(sizeof(int) * defaultcapacity);if (pst->a == NULL){perror("malloc fail\n");return;}pst->size = 0;pst->capacity = defaultcapacity;}

三、缺省参数声明和定义

将栈插入分文件实现是否可行,结果发现不可行,因为缺省时声明和定义不能同时缺省
为什么?如果可行的话,假设在声明时给的缺省值与在定义时给的缺省值并不相同
那么在调用它时如果用哪个缺省值,分不清楚,因此并不能在声明和定义时同时给缺省
在这里插入图片描述
默认参数为缺省参数,重定义了,不可行

不能同时给的话,在缺省给还是定义给?

定义给声明不给

在这里插入图片描述
在这里插入图片描述

程序预处理阶段将头文件展开,得到声明,然后编译阶段走各个源文件查看语法是否出错

在这里插入图片描述
这里调用传参的时候只传一个参数,而声明得到的初始化函数需要有两个参数,这里只传了一个,在编译阶段它只能查看当前文件的语法,并不能去其它源文件中,而在预处理阶段只得到声明并没有得到定义,所以声明没给缺省时编译会报错

声明给定义不给
在这里插入图片描述
在这里插入图片描述
可以发现是编译过了的
在这里插入图片描述

四、全缺省和半缺省

全缺省
函数形参的各个参数都指定一个缺省值
在这里插入图片描述

半缺省
函数形参参数部分缺省

在这里插入图片描述

而缺省参数在缺省时也有要求就是从右往左开始依次缺省,

为什么?因为调用传参是从左往右开始传的,在调用传参时如果有一个参数没给缺省,那么就至少要传一个
而如果是从左往右缺省的,那么最后一个每缺省,参数传参从左往右,传的值被第一个接收,那么导致最后一个没有传参会发生错误
总结:缺省参数从右往左开始缺省,不可跳跃缺省和指定缺省 传参从左往右开始传参,不可跳跃传参和指定传参


点击全文阅读


本文链接:http://zhangshiyu.com/post/60278.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1