【C->Cpp】深度解析#由C迈向Cpp(2)

目录

(一)缺省参数

全缺省参数

半缺省参数

 缺省参数只能在函数的声明中出现:

小结:

 (二)函数重载

函数重载的定义

 三种重载


        在上一篇中,我们从第一个Cpp程序为切入,讲解了Cpp的命名空间要解决的问题,以及输入输出流。

        接下来,开始本篇内容->


【C->Cpp】深度解析#由C迈向Cpp(2)_第1张图片

长长的路,慢慢的走 


(一)缺省参数

 

       缺省参数是Cpp另一个基于C上的新增加的语法,实现一个项目,离不开一个一个的功能,为了更加方便的重复使用同一个功能,我们通常将代码段封装成“高内聚,低耦合”的函数中。

        想要使用函数,一般要向他传递参数。在C中,我们必须按照函数定义时的参数一一对应的传参:

​#include

float sub(float a,int b)
{
	return (float)(a-b);
}

int main()
{
	printf("%lf\n",sub(5.6,4));
	
	return 0;
}

        在Cpp中,有缺省参数的语法:

在函数定义的时候,给参数一个值,这个值是“备用的”,如果这个在调用此函数时,没有给参数传值,那么这个参数就会使用这个设定的默认值。

 


#include

int func(int a = 50)
{
	return a;
}
int main()
{
	std::cout << func(10) << std::endl;
	std::cout << func() << std::endl;
	return 0;
}

a默认值为50,有传值按照传递的值;无传值则默认为50. 

【C->Cpp】深度解析#由C迈向Cpp(2)_第2张图片

 缺省参数按照缺省的情况不同,分为全缺省参数和半缺省参数


 

全缺省参数

 在定义函数的时候,所有的参数都有默认值

//在定义的时候,对所有的参数设置有默认值

void fun_c(int a = 1,int b = 2,int c = 3)
{
	std::cout << "a = " << a << std::endl;
	std::cout << "b = " << b << std::endl;
	std::cout << "c = " << c << std::endl;
}

 


半缺省参数

在定义函数的时候,部分参数有默认值

//部分参数有默认值——第一个参数a没有默认值,其余参数有默认值

void fun_c2(int a,int b = 5,int c = 52)
{
	std::cout << "a = " << a << std::endl;
	std::cout << "b = " << b << std::endl;
	std::cout << "c = " << c << std::endl;
}

 

但是,有默认值的参数要放在函数定义的参数括号的最右侧,否则,编译器报错 

【C->Cpp】深度解析#由C迈向Cpp(2)_第3张图片

 

将有默认值的参数放到函数参数括号的右侧后,没有错误提示

【C->Cpp】深度解析#由C迈向Cpp(2)_第4张图片 


 

 在使用的时候,由于有默认值的参数都放在函数的参数括号的最右侧,无默认值的参数在函数括号的左侧,所以手动传入的参数主要是给无缺省参数的参数。

 无法跨过没有默认值的参数,直接给有默认值的参数传参


void func2(int a ,int b = 5, int c = 8)
{
	std::cout << "a = " << a << std::endl;
	std::cout << "b = " << b << std::endl;
	std::cout << "c = " << c << std::endl;
	std::cout << std::endl;
}

int main()
{
	func2(,1,2);
	func2(1,2);
	return 0;
}

 

【C->Cpp】深度解析#由C迈向Cpp(2)_第5张图片


 缺省参数只能在函数的声明中出现:

在项目内部时,缺省参数统一放在函数的声明中 

 main.cpp


#include"test.h"

int main()
{
	std::cout << add(1,2) << std::endl;
	std::cout << add() << std::endl;
	
	return 0;
}

add.h

#ifndef TEST_H
#define TEST_H

int add(int a = 1,int b = 1);

#endif

 add.cpp


int add(int a,int b)
{
	return a+b;
}

 编译成功,按照传入参数,和为3;按照默认参数,和为2;【C->Cpp】深度解析#由C迈向Cpp(2)_第6张图片


对其他情况:

        在定义中设置默认参数;

        在定义和声明中都设置默认参数;

都无法编译通过。 

 只有在声明中设置默认参数,编译可以成功;


小结:

        1.半缺省参数(有默认值的参数)必须从右向左来给出,不能间隔着给;

         2.缺省参数不能在函数的声明和定义中同时出现,要将缺省参数放在声明中。

 

 (二)函数重载

在C中,我们无法定义任何一个同名的函数。当我们想要实现一系列功能类似,知识数据类型不同的函数时,我们只能在函数名上附带上一些标记:

add_int();
add_dou();
add_flo();
...

这就不利于我们编程。因为当函数类型更多时,记忆十分繁琐。

函数重载是Cpp为了方便编程,在C的基础上添加的新的语法。

 

函数重载的定义

函数重载是在同一个作用域中,可以声明几个功能类似的同名函数,但是需要满足的条件是:函数的形参列表不同->

        具体来说,形参列表不同指的是 参数个数,类型,类型顺序不同

 三种重载

 

 类型不同


int add_(int a,int b)
{
	return a+b;
}
double add_(double a,double b)
{
	return a+b;
}

int main()
{
	std::cout << add_(1,2) << std::endl;
	std::cout << add_(1.5,2.6) << std::endl;
	
	return 0;
}

【C->Cpp】深度解析#由C迈向Cpp(2)_第7张图片

 

参数个数不同


int add_(int a,int b)
{
	return a+b;
}

int add_(int a,int b,int c)
{
	return a+b+c;
}


int main()
{
	std::cout << add_(1,2) << std::endl;
	std::cout << add_(3,5,9) << std::endl;
	
	return 0;
}

【C->Cpp】深度解析#由C迈向Cpp(2)_第8张图片

 

 类型顺序不同


void fun_c4(int a,char c)
{
	std::cout << a << std::endl;
	std::cout << c << std::endl;
}

void fun_c4(char c,int a)
{
	std::cout << a << std::endl;
	std::cout << c << std::endl;
}

int main()
{
	fun_c4(5,'v');
	fun_c4('p',5);
	return 0;
}

【C->Cpp】深度解析#由C迈向Cpp(2)_第9张图片

以上三种情况都是正确的,可以编译通过;编译器似乎可以自动识别函数的参数类型,他根据我们传入参数的类型来自动调用参数类型合适的函数。

 

但是为什么呢? 编译的时候,编译器是怎么识别的呢?

 与C不同的是,Cpp对函数名进行了不同的修饰,同名的函数,由于修饰的内容不同,所以最终Cpp编译器对于同名函数的名称能够区分开。

 

至于如何区分,具体请听下回解析~ 


完~ 

未经作者同意禁止转载 

你可能感兴趣的:(Cpp,开发语言,c++,c语言)