Hi,各位读者们,我是你们的鸭哥!
由于最近公众号的改版,为了保证你们第一时间能看到鸭哥的文章,大家记得将公众号 加星标置顶 哦!来源:https://urlify.cn/JVviuy
最近,有朋友讨论说for循环里不要用list.size(),这样会导致每次都调用一次list.size()接口会耗性能,建议我们在外面使用一个变量来存储这个list.size()的值再放到循环里面,真的是这样吗?
我做了个小测试,代码如下:
public class Test2 { public static void main(String[] args) { List list = new ArrayList(); list.add("1"); list.add("2"); for (int i = 0; i < list.size(); i++) { System.out.println(i); } }}
这里将list.size()放在了for循环里,按朋友的说法,这里应该会调用多次。
接下来我查看了字节码发现,这里确实会调用多次list.size()方法,字节码如下:
具体字节码指令解析可查看:http://www.blogjava.net/DLevin/archive/2011/09/13/358497.html
接着查看了ArrayList调用size()方法的源码是直接返回一个int 型的 size变量的,而这个size变量是每次新增和删除都会改变这个size的值
结论:经过网友们热情的探讨与更正,for循环里会多次调用list.size(),list.size()方法会直接返回一个声明在类中的size全局变量,虽然这个size会直接保存在堆中,但每次发生函数调用确实会发生压栈出栈的性能开销。这里有一个考点,需要注意一下for循环不允许删除与新增元素。
热门推荐:
- 求求你们了,别再写满屏的 if/ else 了!
- MySQL大表优化方案,看了都说棒!
- SQL性能优化,太太太太太太太有用了!
![f3ff579a7437670bb069ff8d572d103e.png](https://i-blog.csdnimg.cn/blog_migrate/7c1dc34bb912812f269020045e7573ba.png)
![5d4b48044ec130284cdcbc4bc47096e4.png](https://i-blog.csdnimg.cn/blog_migrate/95c44608ff0f5f887a55bdd899de7ede.jpeg)
扫描关注,永不迷路