一文彻底搞懂重载函数匹配

本文详细解析了C++中重载函数匹配的过程,包括确定候选函数、可行函数及最佳匹配函数的步骤。介绍了最佳匹配原则,如精确匹配优于类型转换,以及不同类型转换的优先级。同时,通过示例解释了不同类型转换在函数匹配中的应用,并警告了可能出现的二义性问题及其解决方法。
摘要由CSDN通过智能技术生成

前言

前面我们讲到了《函数重载》,有了函数重载之后,就需要确定某次调用需要选用哪个函数。这个过程可以称之为函数匹配或者重载确定。大多数情况下,我们都很容易能够确定某次调用需要选用哪个函数,但事实上不尽然。但通过本文将彻底理清重载函数匹配

 

匹配过程

为便于说明,将函数匹配分为三个阶段,确定候选函数,确定可行函数,确定最佳匹配函数。

确定候选函数

候选函数也就是和被调用的函数同名,并且其声明在调用点可见。举个简单的例子。
假设有两个文件,1.cpp和2.cpp,内容分别如下:
1.cpp:

//函数1
 void f(int a,short b)
 {
     cout<<"func0"<<endl;
 }

2.cpp:

 #include<iostream>
 using namespace std;
 //函数2
 void f(int a,double b)
 {
     cout<<"func1"<<endl;
 }
 //函数3
void f(int a, int b)
 {
     cout<< "func2"<<endl;
 }
 //函数4
 void f1()
 {
     cout<<"func3"<<endl;
 }
 int main()
 {
     f(3,4.5);
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值