[英]Repetitive calculations with sizeof, strlen, etc
假设我有一个大数组,并且正在执行以下操作:
for (int i = 0; i < sizeof(arr)/sizeof(arr[0]); ++i)
printf("arr[%d]=%d\n", i, arr[i]);
当然,东西的sizeof
不应该每次都计算,所以应该是这样的:
size_t len = sizeof(arr)/sizeof(arr[0]);
for (int i = 0; i < len; ++i)
printf("arr[%d]=%d\n", i, arr[i]);
我的问题是是否可以假设任何编译器都会自动进行上述优化,所以我使用哪种方法并不重要? 或者我应该假设情况并非如此,第二种方法是唯一正确的方法。
没有理由将除法提升到循环条件之外。 这甚至不是计算除法多少次的问题(在这些情况下通常关心的是,并且可能需要编译器使用“转义分析”来确定长度值是否可以在迭代之间改变)。 一个简单的事实是sizeof(arr)/sizeof(arr[0])
是一个常量表达式,它将在编译时进行评估,并且与您在那里硬编码一个数字没有什么不同。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.