for循环中的++i和i++

本文详细探讨了在C++中使用前缀++i与后缀i++的区别,包括它们在for循环中的表现与效率差异。通过分析这两种递增操作符的底层实现机制,解释了为何前缀形式通常具有更高的性能。此外,还介绍了这两种形式作为左值与右值时的行为差异。

摘要:for循环中使用++i和i++的区别

 

我们都知道,在for循环中,使用++i有更好的性能。原因是++i返回的是i+1后的本身值,而i++返回的是i+1之前的临时变量,后者要有临时变量的操作,所以前者效率更高。它们的实现如下:

 

  // 前缀形式:
int& int::operator++() //这里返回的是一个引用形式,就是说函数返回值也可以作为一个左值使用
{//函数本身无参,意味着是在自身空间内增加1的
  *this += 1;  // 增加
  return *this;  // 取回值
}

//后缀形式:
const int int::operator++(int) //函数返回值是一个非左值型的,与前缀形式的差别所在。
{//函数带参,说明有另外的空间开辟
  int oldValue = *this;  // 取回值
  ++(*this);  // 增加
  return oldValue;  // 返回被取回的值
}

 

在这里,两种操作的返回值是不一样的,一个是i,一个是临时变量。i可以使用&地址符,而临时变量则不可以。所以++i是左值,而i++是右值。

 

int i = 0;
int *p1 = &(++i); //正确
int *p2 = &(i++); //错误

++i = 1; //正确
i++ = 5; //错误

 

 

虽然,++i和i++在效率上有差别,但它们在for循环中所体现的作用是一致的,并不会造成循环次数的差异,原因在于在for循环中,对++i和i++是一个独立的语句,它们并不是判断语句的左操作数。

 

//前缀形式    
  ++i;
  i!=n;
  
//后缀形式
  i++;
  i!=n;

 

 

 

 

 

 

 

 

 

 

评论