c++中的函数重载(c++多态的特性)

本文介绍了函数重载的概念,包括其条件(参数数量、类型和顺序的不同)、注意事项(如返回值类型和默认参数可能导致的二义性),以及编译器如何在幕后处理函数重载的过程。举例说明了Linux下不同函数的编译后名称

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1、函数重载:同一个函数名在不同场景下可以具有不同的含义

2、函数重载条件:同一作用域参数个数不同,参数类型不同,参数顺序不同

注意:

3、函数重载的原理:


1、函数重载:同一个函数名在不同场景下可以具有不同的含义

2、函数重载条件:同一作用域参数个数不同,参数类型不同,参数顺序不同

代码示例:

void func() {
	cout << "无参的func" << endl;
}
void func(int a) {
	cout << "一个参数的func" << endl;
}
void func(int a,int b) {
	cout << "两个参数的func" << endl;
}
void func(char a) {
	cout << "char类型的func" << endl;
}
void func(double a) {
	cout << "double类型的func" << endl;
}
void test() {
	func();
	func(10);
	func(10, 10);
	func(20.2);
	func('a');
}
int main() {
	test();
}

运行结果:

注意:

1、函数的返回值类型不能作为函数重载的依据

2、 函数重载和默认参数一起使用,需要格外注意二义性问题的产生

此时调用myfuc(20)函数,编译器可以与一个参数的myfunc匹配,也可以与具有默认参数的两个参数myfunc匹配,这时候系统就不知道调用那个了,就产生了二义性问题。

3、函数重载的原理:

编译器为了实现函数重载,也是默认为我们做了一些幕后的工作,编译器用不同的参数类型来修饰不同的函数名,比如 void func;编译器可能会将函数名修饰成func,当编译器碰到void func(intx)编译器能将丽数名修饰为funcint;当编译器碰到void func(int x ,char c)编译器可能会将函数名修饰为funcintchar 我这里使用"可能”这个字眼是因为编译器如何修饰重载的函数名称并没有一个统一的标准,所以不同的编译器可能会产生不同的内部名。
void func(){}

void func(int x){}

void func(int x,char y){}

以下三个函数在 linux下生成的编译之后的函数名为:

Z4funcv //v 代表void,无参数

Z4funci //i 代表参数为int类型

Z4funcic //i 代表第一个参数为 int 类型,第二个参数为 char 类型

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

晚笛诶

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

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

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

打赏作者

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

抵扣说明:

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

余额充值