i++与++i主要区别有两个:
1)i++返回加1前的值,++i返回加1后的值;
2)i++不能作为左值,而++i可以。
注:★左值是对应内存中有确定存储地址的对象的表达式的值,而右值是所有不是左值的表达式的值。(引用自中文维基百科【左值引用】)
★能否被赋值不是区分左值与右值的依据。比如,C++的const左值是不可赋值的;而作为临时对象的右值可能允许被赋值。左值与右值的根本区别在于是否允许取地址&运算符获得相应的内存地址。
举个栗子:
1. 是否允许取地址
#include <iostream>
using namespace std;
int main()
{
int i = 1;
int* p1 = &(++ i); //正确
int* p2 = &(i ++); //错误
return 0;
}
可见,i++无法取得相应的内存地址。
2. 返回值
#include <iostream>
using namespace std;
int main()
{
int i = 1;
++ i = 4; //正确
i++ = 5; //错误
return 0;
}
可见,++ i可以作为左值。
为什么++i可以作为左值,而i++不可以,参见其具体实现:
// 前缀形式:
int& int::operator++() //这里返回的是一个引用形式,即函数返回值也可以作为一个左值使用
{//函数本身无参,意味着是在自身空间内增加1的
*this += 1; // 增加
return *this; // 取回值
}
//后缀形式:
const int int::operator++(int) //函数返回值是一个非左值型的,与前缀形式的差别所在。
{//函数带参,说明有另外的空间开辟
int oldValue = *this; // 取回值
++(*this); // 增加
return oldValue; // 返回被取回的值
}
注:i++最后返回的是一个临时变量,而临时变量是右值。