C++57个入门知识点_04_ 默认参数(调用多参数函数,少数参数有固定值或改变情况使用、int TestFoo(int n1,int n2=2)TestFoo(1)、此处为函数,类处为初始化列表)

C++中我们可能会调用参数较多的复杂函数,这种情况下按照默认的操作,我们需要写出对应个数的参数,但是当我们使用的时候大部分参数不变,只有1、2个变化的话就显得十分不方便。C++11中提供了默认参数的方法,假定某些参数是固定值,传递时就不需要写有固定值的参数。

默认参数的实现方法:

  • c++中提供了将某一些参数赋予固定值,在调用时这些参数按照固定值赋予
  • 原始参数只有n1,n2,n3,后边添加更多变量n4,n5,n6,如果调用时后3个参数保持默认参数
  • 方法1:宏定义 #define TESTFOO(m,n,k) TestFoo(m,n,k,1,2,3),但缺点时后三位参数值不好改变,另外宏参数是没有类型检查的
  • 方法2:利用C++的语法来进行写,默认的参数提前赋值TestFoo(int n1, int n2, int n3, int n4=4, int n5=5, int n6=6)
  • 当需要改变第四个参数值,只需要在调用时给第四个参数赋值即可改变

1. 函数调用的常规用法

下为常规的函数调用的方法,有几个参数调用时就写几个

#include <iostream>

int TestFoo(int n1, int n2, int n3)
{

	return 0;//作为Int类型函数必须有返回值,无此句,报错:必须有返回值
}

int main(int nArgc, char* pArgv[])
{
	//不适用默认参数的调用形式
	TestFoo(1, 2, 3);
}

2. 宏实现默认参数


当参数中存在固定值时,我们可以通过宏的方式来实现,具体代码如下:

#include <iostream>

//前三位参数采用自定义值,后三位采用固定值1,2,3
#define TESTFOO(m,n,k) TestFoo(m,n,k,1,2,3)

int TestFoo(int n1, int n2, int n3,int n4, int n5,int n6)
{
	return 0;
}

int main(int nArgc, char* pArgv[])
{
	TESTFOO(1, 2, 3);
}

运行结果:n4n5n6均使用宏中的默认值
在这里插入图片描述

使用宏的缺点:调用函数一旦后边3个参数中的某一个需要发生改变时就需要再写一个宏,另外宏中的参数数据类型是无法检查的

3. C++实现默认参数写法


C++为了解决上面的问题,提出了默认参数的用法,具体写法如下:

#include <iostream>
int TestFoo(int n1, int n2, int n3,int n4=4, int n5=5,int n6=6)
{
	return 0;
}

int main(int nArgc, char* pArgv[])
{
	TestFoo(1, 2, 3);
}

运行结果:参数值固定的在调用时就会使用固定值
在这里插入图片描述

4. C++人为修改默认参数

对默认参数的值我们也可以在不更改函数的情况下人为的去修改:

#include <iostream>
int TestFoo(int n1, int n2, int n3,int n4=4, int n5=5,int n6=6)
{
	return 0;
}

int main(int nArgc, char* pArgv[])
{
	TestFoo(1, 2, 3,44);
}

运行结果:固定值在调用时被修改
在这里插入图片描述

5. 默认参数的相关性质

  • 函数允许提供默认参
  • 默认参可以写在声明或者定义处,但默认参数只能出现在一个地方,一般写在声明(.h)处,头文件是可以暴露在外的,这样其他人可以看到哪些是默认参数
  • 当一个参数有默认参时,该参数的右边必须都出现默认参,否则编译混乱
    即不能出现int TestFoo(int n1, int n2, int n3, int n4=4, int n5=5, int n6),当调用int TestFoo(1,2,3,4,5)时就会产生二意性,编译器可以理解4,5是修改n4/n5默认值,也可以认为是给n6赋值

6. 学习视频地址:C++57个入门知识点_04_ 默认参数

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
目录 1、 C++对C的扩展 1 1简单的C++程序 1 1.1求圆的周长和面积 1 1.2初学者易犯错误模型 3 2程序设计方法的发展历程 4 3 C语言和C++语言关系 6 4 C++对C的加强 6 4.1 namespace命名空间 6 4.2 “实用性”增加 6 4.3 register关键字增强 6 4.4变量检测增强 6 4.5 struct类型加强 6 4.6 C++中所有的变量和函数都必须有类型 6 4.7新增Bool类型关键字 6 4.8三目运算符功能增强 6 5 C/C++中的const 6 1 const基础知识(用法、含义、好) 6 2 C中“冒牌货” 6 3 const和#define相同之 6 4 const和#define的区别 6 5 结论 6 6引用专题讲座 6 1引用(普通引用) 6 2常引用 6 3 const引用结论 6 4const修饰类 6 5综合练习 6 7C++对C的函数扩展 6 1 inline内联函数 6 2 默认参数 6 3 函数占位参数 6 4 默认参数和占位参数 6 5 函数重载(Overroad) 6 8附录 6 附录1:C++语言对C语言扩充和增强的几点具体体现 6 附录2:C语言register关键字—最快的关键字 6 一、皇帝身边的小太监----寄存器 6 2、类和对象 6 1前言 6 2类和对象 6 2.1 基本概念 6 2.2类的封装 6 2.3 C++面向对象程序设计举例 6 2.4 作业 6 3对象的构造和析构 6 3.1构造和析构函数 6 3.2构造函数的分类及调用 6 3.3构造函数调用规则研究 6 3.4深拷贝和浅拷贝 6 3.5多个对象构造和析构 6 3.6构造函数和析构函数调用顺序研究 6 3.7构造函数和析构函数综合练习 6 3.8 对象的动态建立和释放 6 4静态成员变量成员函数 6 4.1静态成员变量 6 4.2静态成员函数 6 4.3综合训练 6 5 C++面向对象模型初探 6 5.1基础知识 6 5.2编译器对属性和方法的理机制 6 5.3总结 6 5.4 this指针 6 5.5全局函数PK成员函数 6 6 6友元 6 6.1友元函数 6 6.2友元类 6 7强化训练 6 1 static关键字强化训练题 6 2 数组类封装 6 3小结 6 8运算符重载 6 8.1概念 6 8.2运算符重载的限制 6 8.3运算符重载编程基础 6 8.4运算符重载提高 6 8.5运算符重载在项目开发中的应用 6 8.7附录:运算符和结合性 6 2、 继承和派生 6 3.1继承概念 6 3.1.1类之间的关系 6 3.1.2继承关系举例 6 3.1.3 继承相关概念 6 3.1.4 派生类的定义 6 3.1.5 继承重要说明 6 3.2派生类的访问控制 6 3.2.1单个类的访问控制 6 3.2.2不同的继承方式会改变继承成员的访问属性 6 3.2.3“三看”原则 6 3.2.3派生类类成员访问级别设置的原则 6 3.2.4综合训练 6 3.3继承中的构造和析构 6 3.3.1类型兼容性原则 6 3.3.2继承中的对象模型 6 3.3.3继承中的构造析构调用原则 6 3.3.4继承与组合混搭情况下,构造和析构调用原则 6 3.3.5继承中的同名成员变量理方法 6 3.3.6派生类中的static关键字 6 3.4多继承 6 3.4.1多继承的应用 6 3.4.2虚继承 6 3.5继承总结 6 4、多态 6 4.1多态 6 4.1.1问题引出 6 4.1.2面向对象新需求 6 4.1.3解决方案 6 4.1.4多态实例 6 4.1.5多态工程意义 6 4.1.6多态成立的条件 6 4.1.7多态的理论基础 6 4.2多态相关面试题 6 面试题1:请谈谈你对多态的理解 6 面试题2:谈谈C++编译器是如何实现多态 6 面试题3:谈谈你对重写,重载理解 6 #include <cstdlib> 6 #include <iostream> 6 using namespace std; 6 class Parent01 6 { 6 public: 6 Parent01() 6 { 6 cout<<"Parent01:printf()..do"<<endl; 6 } 6 public: 6 virtual void func() 6 { 6 cout<<"Parent01:void func()"<<endl; 6 } 6 virtual void func(int i) 6 { 6 cout<<"Parent:void func(int i)"<<endl; 6 } 6 virtual void func(int i, int j) 6 { 6 cout<<"Parent:void func(int i, int j)"<<endl; 6 } 6 }; 6 class Child01 : public Parent01 6 { 6 public: 6 //此2个参数,和子类func函数是什么关系 6 void func(int i, int j) 6 { 6 cout<<"Child:void func(int i, int j)"<<" "<<i + j<<endl; 6 } 6 //此3个参数的,和子类func函数是什么关系 6 void func(int i, int j, int k) 6 { 6 cout<<"Child:void func(int i, int j, int k)"<<" "<<i + j + k<<endl; 6 } 6 }; 6 void run01(Parent01* p) 6 { 6 p->func(1, 2); 6 } 6 int main() 6 { 6 Parent01 p; 6 p.func(); 6 p.func(1); 6 p.func(1, 2); 6 Child01 c; 6 //c.func(); //问题1 6 c.Parent01::func(); 6 c.func(1, 2); 6 run01(&p); 6 run01(&c); 6 system("pause"); 6 return 0; 6 } 6 //问题1:child对象继承父类对象的func,请问这句话能运行吗?why 6 //c.func(); //因为名称覆盖,C++编译器不会去父类中寻找0个参数的func函数,只会在子类中找func函数。 6 //1子类里面的func无法重载父类里面的func 6 //2当父类和子类有相同的函数名、变量名出现,发生名称覆盖(子类的函数名,覆盖了父类的函数名。) 6 //3//c.Parent::func(); 6 //问题2 子类的两个func和父类里的三个func函数是什么关系? 6 面试题4:是否可类的每个成员函数都声明为虚函数,为什么。 c++编译器多态实现原理 6 面试题5:构造函数调用函数能实现多态吗?为什么? c++编译器多态实现原理 6 面试题6:虚函数表指针(VPTR)被编译器初始化的过程,你是如何理解的? 6 面试题7:父类的构造函数调用函数,能发生多态吗? c++编译器多态实现原理 6 面试题8:为什么要定义虚析构函数? 6 其他 6 4.3多态原理探究 6 4.3.1 多态的实现原理 6 4.3.2如何证明vptr指针的存在 6 4.3.3构造函数中能调用函数,实现多态吗 6 5、纯虚函数和抽象类 6 5.1基本概念 6 5.2抽象类案例 6 5.3抽象类在多继承中的应用 6 5.3.1有关多继承的说明 6 5.3.2多继承的应用场景 6 5.4抽象类知识点强化 6 5.5面向抽象类编程思想强化 6 5.4.1案例:socket库c++模型设计和实现 6 5.4.2案例:计算员工工资 6 5.4.3案例:计算几何体的表面积和体积 6 5.6 C面向接口编程和C多态 6 5.6.1函数类型语法基础 6 5.6.2函数指针做函数参数 6 5.6.3函数指针正向调用 6 5.6.4函数指针反向调用 6 5.6.5.C动态库升级成框架案例 6 5.6.6附录:诸葛亮的锦囊妙计 6

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

十月旧城

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值