在网上看到一篇文章,里面说i++和i--的效率有区别,这个区别我早就知道,其实就是一个标志寄存器的重用问题,虽然早就知道还是想写出来来展示一下计算的魅力,这两个例子是:
int loop_dec(int n)
{
int i = 0;
int v = 0;
for(i = n; i > 0; i--)
v +=i;
return v;
}
int loop_inc(int n)
{
int i = 0;
int v = 0;
for(i = 0; i < n; i++)
v +=i;
return v;
}
我们要想得到其中的奥妙只有通过汇编来说明,于是objdump一下上面的两个函数发现用dec的函数会少一个cmp语句, 为何呢?其实这个i--效率高并不是--比++有什么特殊的,而是巧在这是和0比较,众所周知,cpu的寄存器中有进位和溢出相关的东西,本来是正数,一旦小于0了,可以通过状态寄存器看出来,而cpu指令中也有根据状态寄存器跳转的指令,这样我们就可以利用这些了,就是这么简单,没有什么大不了的,不信你把和0比较换成和1比较,i--的优势就没有了,要知道,0永远都是最具魅力的数字
原文链接: https://blog.csdn.net/dog250/article/details/5303375
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;
也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/410338
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!