增量运算

来源:互联网 发布:破解软件授权码 编辑:程序博客网 时间:2024/04/30 00:08

免责任声明:

1. 这里不讨论 a = (a++) + (++a) ;这种脑残表达式 (不管你怎么黑它依旧存在于天朝应试题中)

2.如有不正确清指出 不然又要误导祖国的花朵们

3.以下言论仅代表个人观点.

 

好吧进入正题

 

 

 ——————————————————————————严肃的分割线————————————————————————————

 

 

有人问我为啥是

for(int i = 0; i < 1;++i);

而不是

for(int i = 0; i < 1; i++);

 

首先得搞清楚 i++ 和 ++i这两个都做了啥操作

随便找一本C语言的书,它都会告诉你这两个操作都让i+了一个1

不同点是 a = i++ ; a的数值是i+1之前的值

a = ++i 的数值是i+1之后的值

 

这样看,从逻辑上来 单独的i++和 ++i并没有什么区别

不过。。。。

 

++i

运算过程中,先将对象进行递增修改,而后返回该对象,返回值采用引用的方式

 

i++
运算过程中,先返回原有对象的值,而后进行对象递增运算,返回值采用返回一个拷贝构造

也就是说,i++ 它。。它在冥冥之中多了一次构造的消耗,性能上有一定的损耗(其实我也不是很在意了)

 

 

 

结论:

当你只要进行一次+1的操作 如

for (int i = 0; i < 1; ++i);

这时候请采用 ++i  这种方式累加

如果需要+1之前的值时 如

map.erase(iterater--);

才可以采用 i++  这种略有消耗的运算方式

 

原创粉丝点击