首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

是什么让一个重载函数优先于另一个重载函数?

重载函数是指在同一个作用域内,函数名相同但参数列表不同的多个函数。当调用一个重载函数时,编译器会根据传入的参数类型和数量来确定应该调用哪个重载函数。

在确定哪个重载函数优先调用时,编译器会按照以下规则进行匹配:

  1. 精确匹配:如果有一个重载函数的参数类型与传入参数的类型完全匹配,则选择该重载函数。例如,如果有一个重载函数的参数为int类型,而传入的参数也是int类型,则选择该重载函数。
  2. 类型提升:如果没有找到精确匹配的重载函数,编译器会尝试将传入参数的类型提升为其他类型,然后再进行匹配。例如,如果有一个重载函数的参数为float类型,而传入的参数为int类型,则编译器会将int类型提升为float类型,然后选择该重载函数。
  3. 标准类型转换:如果没有找到精确匹配或类型提升的重载函数,编译器会尝试进行标准类型转换,将传入参数的类型转换为重载函数参数类型。例如,如果有一个重载函数的参数为double类型,而传入的参数为int类型,则编译器会将int类型转换为double类型,然后选择该重载函数。
  4. 用户自定义类型转换:如果没有找到以上匹配方式的重载函数,编译器会尝试进行用户自定义类型转换。用户可以通过定义类型转换函数或者类型转换构造函数来实现自定义类型转换。例如,如果有一个重载函数的参数为自定义类型A,而传入的参数为自定义类型B,而类型B可以通过类型转换函数或者类型转换构造函数转换为类型A,则选择该重载函数。

总结起来,重载函数的优先级是根据参数类型的匹配程度来确定的,精确匹配优先于类型提升,类型提升优先于标准类型转换,标准类型转换优先于用户自定义类型转换。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 《挑战30天C++入门极限》C++运算符重载转换运算符

    当一个类含有转换运算符重载函数的时候,有时候会破坏C++原有规则,导致运算效率降低,这一点不得不注意。   示例如下: //例3 //程序作者:管宁 //站点:www.cndev-lab.com //所有稿件均有版权,如要转载,请务必著名出处和作者 #include <iostream> using namespace std; class Test { public: Test(int a = 0) { cout<<this<<":"<<"载入构造函数!"<<a<<endl; Test::a = a; } Test(Test &temp) { cout<<"载入拷贝构造函数!"<<endl; Test::a = temp.a; } ~Test() { cout<<this<<":"<<"载入析构函数!"<<this->a<<endl; cin.get(); } operator int()//转换运算符,去掉则不会调用 { cout<<this<<":"<<"载入转换运算符函数的内存地址:"<<this->a<<endl; return Test::a; } public: int a; }; int main() { Test b=Test(99);//注意这里 cout<<"b的内存地址"<<&b<<endl; cout<<b.a<<endl; system("pause"); }   按照C++对无名对象的约定,Test b=Test(99);C++是会按照Test b(99);来处理的,可是由于转换运算符的加入,导致这一规律被破坏,系统会“错误的”认为你是要给对象赋值,所以系统首先利用Test(99)创建一个临时对象用于赋值过程使用,可是恰恰系统又没有使用自动提供的赋值运算重载函数去处理,因为发现b对象并未构造,转而又不得不将开始原本用于赋值而创建的临时对象再次的强转换为int类型,提供给b对象进行构造,可见中间的创建临时对象和载入转换运算符函数的过程完全是多余,读者对此例要认真解读,充分理解。   运行结果如下图所示(运行过程的解释见图):

    02
    领券