Chinaunix

标题: for循环的第二个条件如果有表达式,那么是会被反复执行吗? [打印本页]

作者: cdsfiui    时间: 2016-12-03 15:17
标题: for循环的第二个条件如果有表达式,那么是会被反复执行吗?
例如,我只是遍历一个vector的元素,如果用下标的方式,那么

for(size_t i=0;i<v.size();++i)
{...}

我想问,这个v.size()是会执行一次,还是会执行多次? 还是说编译器会做出适当的优化,让我不需要去
size_t s=v.size()
for(size_t i=0;i<s;++i)

这样避免重复调用?

换句话说,我想知道编译器在这里是否有能力对for循环的第二个条件,也就是v.size()这个语句,做出合适的优化?



作者: MMMIX    时间: 2016-12-03 15:47
回复 1# cdsfiui

把优化打开看看最后的汇编不就清楚了?
作者: yulihua49    时间: 2016-12-03 15:50
cdsfiui 发表于 2016-12-03 15:17
例如,我只是遍历一个vector的元素,如果用下标的方式,那么

for(size_t i=0;i

看v 是否有变化。循环内不变化的就被优化掉。

作者: lxyscls    时间: 2016-12-05 10:13
回复 1# cdsfiui

你都知道第二种更好,何必再浪费时间纠结于第一种?
不过如果vector的size中途变掉的话,那么第二种也就没用了不是?

作者: windoze    时间: 2016-12-05 14:51
本帖最后由 windoze 于 2016-12-05 14:52 编辑

简单说,会。因为size在循环过程中可能会变。
当然具体情况下有可能被优化掉,但这个时候多次和一次并没有什么区别。

作者: 爻易    时间: 2016-12-06 21:56
刷三遍(”这是有副作用的语言!!!“);
作者: hhuangfh    时间: 2016-12-22 16:32
回复 1# cdsfiui


好的编译器是不会做这样打优化的,循环语句内部如果对vector有插入/删除操作,优化了时有问题的。总不能要求编译器编译时先要判断是否有这种情况吧。

作者: shang2010    时间: 2016-12-22 22:31
理论上v.size()也仅仅是获取一个保护的变量,虽有点开销但夜不算多大的性能优化吧。
作者: cjaizss    时间: 2016-12-23 11:02
看编译器设计的原则,如果STL和编译器设计上独立的,则不会作此优化.
作者: hellioncu    时间: 2016-12-23 13:39
如果循环中对v都是const的操作,那么优化掉不会有问题
作者: shang2010    时间: 2016-12-24 20:44
回复 9# cjaizss

根本就没必要优化,因为是vector,get size运算又不复杂,没必要的优化


开编译器优化也是脑残

作者: sditmaner    时间: 2016-12-25 13:16
回复 1# cdsfiui




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2