访问 'array.length' 的性能成本
问:调用 'array.length' 的计算成本是否比调用 'array.length' 的计算成本更高访问常规变量?
为了通过将 for 循环转换为 for-each 循环来优化代码,许多开发人员遇到如下构造:
for (int i = 0, n = a.length; i < n; i++) { ... }
其中 a 是数组。有人质疑,与完全省略 n 相比,使用 a.length 初始化 n 是否会带来性能损失:
for (int i = 0; i < a.length; i++) { ... }
A:不,调用 'array.length' 的时间为常数(O(1)) cost.
与集合的 size() 方法不同,每次调用都会产生性能开销,访问 array.length 相当于读取局部变量。这是因为 array.length 是数组类的公共最终成员,因此访问速度与任何其他变量一样快。
JIT 编译器的优化
现代即时 (JIT) 编译器通常通过完全消除对 array.length 的调用来优化它们。这是因为编译器可以确定数组的长度在整个循环执行过程中保持不变。
通过代码分析确认
array.length 访问的效率可以通过检查 JVM 的 JIT 编译器生成的本机代码来验证。在大多数情况下,对 array.length 的调用将被优化。
规则的例外
在某些情况下,JIT 编译器可能无法优化 array.length 访问:
以上是## 访问'array.length”真的是性能瓶颈吗?的详细内容。更多信息请关注PHP中文网其他相关文章!