比如下面的代码
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