为什么前缀增量器重载返回类型而不是类型?
Why does Prefix Incrementor Overload return Type& instead of Type?
刚开始做运算符重载,我的老师没有太深入地研究它们,所以我想知道为什么前缀/后缀递增/递减的返回类型不同。当我看到前缀重载时,返回类型写为 Type&,但后缀的返回类型写为 Type。我做了没有 & 的前缀,函数都运行正常。返回类型是否会影响任何内容,或者它只是区分前缀和后缀的另一种方法?
原因是允许链接:
++ ++ ++ i;
若要允许i
以三倍递增,++
必须返回引用并获取引用。如果它返回临时副本,则第二个++
将递增...临时副本(实际上,临时副本不会绑定&
,因此它甚至不会编译(。
为了添加到 Emilio 的答案中,后缀递增会创建一个临时变量并将其设置为 1 加上您要递增的变量,其中前缀递增会增加实际变量,在某些情况下可以提高性能。
主要原因是遵循C++中内置类型的语义,其中前缀递增/递减返回左值,后缀一返回右值。详细信息可以在这里找到
相关文章:
- 如何获取std::result_of函数的返回类型
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 为什么返回类型中需要typename?C++
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 推导 std::vector::back() 的返回类型
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- QtQuick - qml:28:错误:未知方法返回类型:自定义类型
- 基于返回类型的转换和过载扣除
- 如何在模板参数中分离函数类型返回类型和参数