c++(9)默认参数、函数重载、重载的底层实现

1、默认参数表

必须在函数声明时,定义默认参数,且必须从后往前定义。

2、函数重载

function overload,用同一个函数名定义不同的函数,当函数名和不同的参数搭配时函数的含义不同。但是函数返回值并不是构成函数重载的条件,即只是函数形参列表相同、函数名相同,但是函数返回值是不同的类型,那么这两个函数不构成函数重载,会报错重定义。

函数重载,尽量不要写默认参数,避免调用时发生歧义,编译器不通过。

重载规则:(1)、函数名相同。(2)、参数个数不同、参数类型不同、参数顺序不同,均可以构成重载。(3)、返回值类型不同则不可以构成重载。

调用准则:(1)、严格匹配,找到则调用。(2)、通过隐式转换寻求一个匹配,找到则调用。

3、重载的底层实现

c++利用name mangling(倾轧)技术,来改名函数名,驱动参数不同的同名函数。

实现原理:用v c i f l d表示void char int float long double及其应用。

其实在函数的底层,给编译器的时候函数重载仍然是不同的函数名。说白了,到底c++还是通过C语言来实现的,毕竟C语言是不存在重名函数的概念的。

4、函数指针和函数重载

#include <iostream>
#include <cstring>
using namespace std;

int func(int a, int b)
{
	cout<<"func(int, int)"<<endl;
	return 0;
}

int func(int a, int b, int c)
{
	cout<<"func(int, int, int)"<<endl;
	return 0;
}

//如何定义一个类型指向一个函数func
//方式1,直接定义一种函数类型
typedef int(MY_FUNC)(int, int);

//方式2,函数指针,定义一个指针、指向该函数类型的函数
typedef int(* MY_FUNC_P)(int, int);

int main(void)
{
	//1
	MY_FUNC *fp = NULL;
	fp = func;
	fp(10, 20);

	//2
	MY_FUNC_P fp1 = NULL;
	fp1 = func;
	fp1(10, 20);
	
	//方式3
	int (*fp2)(int, int) = NULL;
	fp2 = func;
	fp2(10, 20);
	
	return 0;
}

函数指针,经常用做回调函数的入参,在typedef的时候,规定了指向的函数地址。

实际上在给函数指针赋值的时候,是会发生函数重载,自动匹配对应的函数。但是在函数指针调用的时候,并不能发生重载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值