C++中基于形参是否为引用的重载(奇怪的重载)

C++中基于形参是否为引用的重载(奇怪的重载)

无意间发现,根据形参是否为引用的不同,也可以实现重载,但是调用时会出问题.

比如下面的代码

[cpp]  view plain  copy
  1. void f(int i)  
  2. {  
  3.     cout<<"int";  
  4. }  
  5. void f(int& i)  
  6. {  
  7.     cout<<"int&";  
  8. }   
  9. int main()  
  10. {  
  11.     int x=2;  
  12.     f(x);  
  13.     return 0;  
  14. }  

编译器报调用二义(ambiguous)的错误,如果传一个常量,则会调用f(int)的版本,比如调用f(2);

原因是如果传int型的变量,会由于两个都是精确匹配因此产生二义,而如果本身不是个int类型,而是其他的比如double类型,则会产生一个临时变量赋给整型形参,但临时变量不能被赋给整型的引用,所以会只匹配不是引用的那个版本

然后,我就好奇,如何才能调用到引用的版本呢,尝试了几个都仍然调的是非引用的版本,最后在stackoverflow上找到一个方法,the resolution is a bit more tricky.

方法是利用强制转型把函数f转成引用的那个函数指针类型,即用static_cast<void(*)(int&)>(f)(x);去调用,平常一般都是想着把参数强制转换,第一次看到把函数强制转换的,完全没想到啊,不过貌似用C的强制类型转化语法(即只加括号去强制转型)也会不能成功。

不过如果这两个函数是在类里面,也就是说调用时在函数前还要加个对象,这个时候似乎就不能转型了,会报语法错,可能我写法有问题,暂无解决方案。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值