++i 与 i ++的区别与效率问题

本文转载自:http://www.cplusplus.me/1303.html


2014届搜狗校招笔试题再次提到了这个经典的问题,去百度上查资料解答是:

(1):++i是在i上直接加1,表达式的值是i本身
i++也是在i上加1,表达式的值是加1前的副本
因为要存副本,所以效率略低,但是实际上大部分编译器都会完成这部分优化工作,但是对于自定义的迭代器之类的,就未必有优化了。

++i相当于下列代码:
	i += 1;
	return i;
i++相当于下列代码:
	j = i;
	i += 1;
	return j;// return j 需要注意。
当然如果编译器会将这些差别都优化掉,那么效率就都差不多了。


(2):如果i是内置类型的,如int,效率是一样的(没有拷贝构造函数)。
如果是非内置类型的。如自定义类型A:
A& A::operator++();//++A
const A A::operator++(int);//A++,返回对象,调用拷贝构造函数
所以++A效率更高些。


(3):c++Primer上面有说:对于老旧的编译器++i效率好,对于好的编译器i++被优化了(效率一样)。表示该用哪个用哪个。


(4):1、当变量i的数据类型是c++语言默认提供的类型的话,他们的效率是一样的。

<span style="font-size:18px;">int a, i = 0; a = ++i;
//汇编代码如下:

int a, i = 0;
01221A4E mov dword ptr [i],0
a = ++ i;
01221A55 mov eax,dword ptr [i]
01221A58 add eax,1
01221A5B mov dword ptr [i],eax
01221A5E mov ecx,dword ptr [i]
01221A61 mov dword ptr [a],ecx
-------------------------------
int a, i = 0; a = i++;
//汇编代码如下:

int a, i = 0;
009E1A4E mov dword ptr [i],0
a = i++;
009E1A55 mov eax,dword ptr [i]
009E1A58 mov dword ptr [a],eax
009E1A5B mov ecx,dword ptr [i]
009E1A5E add ecx,1
009E1A61 mov dword ptr [i],ecx</span>



从汇编代码可以看出,他们的执行行数是一样的!

2、我们自定的数据类型,++i效率高于i++,通过运算符重载来给大家说明这一点。

<span style="font-size:18px;">Operator Operator::operator++()
{
    ++value; //内部成员变量 
    return *this;
}
---------------------------------
Operator Operator::operator++(int)
{
    Operator temp;
    temp.value=value;
    value++;
    return temp;
}
</span>

看到了吗?后++必须要有一个临时对象才可以完成。所以他的效率自然就下降了!

(4)解答是个人感觉是最靠谱的答案,就是在某种情况下(自定义类型),++i的效率确实高于i++;

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值