本篇内容介绍了“C++11引用合并怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
实参推断
考虑下面的模板函数和调用代码。
对于前两种情况,编译器可以根据输入的类型很简单的判断参数类型分别为整数和浮点数;对于第三种情况,编译器无法找到const char*乘2的合理解释,所以结果就是编译错误。
左值引用参数的类型推断
如果参数类型是左值引用的话,事情就会变得复杂一些。例如下面的代码。
对于上面这个模板函数,下面的代码可以正常通过编译。
原因当然是因为可以正确进行参数类型推断。例如当实际的参数类型为int时,模板参数可以理解为:
右值引用参数的类型推断
C++11引入了右值引用之后,程序员可以定义下面的模板函数。
对于这个模板函数,因为实参都是右值,所以下面的调用方式都是合法的。
如果像下面的代码一样,实参是引用类型呢?
为了看得更清楚,这里沿用前面的类型带入的方法,当T为int&的时候,f3变成了下面的样子:
注意红线上的部分,涉及到C++11的另一个新特性,当引用和右值引用同时出现时,遵循下面的原则:
左值引用 + 左值引用 = 左值引用
左值引用 + 右值引用 = 左值引用
右值引用 + 左值引用 = 左值引用
右值引用 + 右值引用 = 右值引用
归纳起来原则很简单:永远是左值优先。这种现象称为引用合并(reference collapse)。
根据上面的原则,代码可再次变形:
以下是执行结果:
f3执行之后,lf的值变成了10。
“C++11引用合并怎么实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!