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

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

比如下面的代码

void f(int i)
{
    cout<<"int";
}
void f(int& i)
{
    cout<<"int&";
} 
int main()
{
	int x=2;
	f(x);
	return 0;
}

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

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

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

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

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


参考:http://*.com/questions/13368474/ambiguous-call-to-overloaded-function-int-and-int

C++中基于形参是否为引用的重载(奇怪的重载),布布扣,bubuko.com

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

上一篇:[MySQL] group by 聚合函数的原理和聚合限制原因SELECT list is not in GROUP BY clause and contains nonaggregated column


下一篇:第一个JDBC程序