比较Java循环的性能
来源:互联网 发布:淘宝客服业绩 编辑:程序博客网 时间:2024/05/17 23:38
Java语言中,常用的循环语句有4种。这些循环是编写Java代码必然会涉及到的控制流语句,片段代码如下。
1. For each 语句
这个循环式在Java5中引进的,优点是很简洁。
- private List<Integer> list = new ArrayList<>();
- for(Integer i : list){
- // 业务逻辑
- }
- private List<Integer> list = new ArrayList<>();
- for(int j = 0; j < list.size() ; j++){
- //业务逻辑
- }
- private List<Integer> list = new ArrayList<>();
- int size = list.size()
- for(int j = 0; j < list.size() ; j++){
- //
- }
- private List<Integer> list = new ArrayList<>();
- for(int j = list.size(); j > size ; j--){
- //<span style="font-family: 'Segoe UI', 'Lucida Grande', Verdana, Arial;">业务逻辑</span>
- }
比较这4种方式的性能,请看下面的程序。
- public class LoopPerformance {
- private static List<Integer> list = new ArrayList<Integer>(1000000);
- static {
- for (int i = 0; i < 10000000; i++) {
- list.add(i);
- }
- }
- public void testLoopPerformance(){
- long startTime;
- long endTime;
- //style 1
- startTime = System.nanoTime();
- for (Integer i : list) {
- //
- }
- endTime = System.nanoTime();
- System.out.println("For each loop :: " + (endTime - startTime) + " ms");
- //style 2
- startTime = System.nanoTime();
- for (int j = 0; j < list.size(); j++) {
- //
- }
- endTime = System.nanoTime();
- System.out.println("Using collection.size() :: " + (endTime - startTime) + " ms");
- //style 3
- startTime = System.nanoTime();
- int size = list.size();
- for (int j = 0; j < size; j++) {
- //
- }
- endTime = System.nanoTime();
- System.out.println("Using [int size = list.size(); int j = 0; j < size ; j++] :: " + (endTime - startTime) + " ms");
- //style 4
- startTime = System.nanoTime();
- for (int j = list.size(); j > 0; j--) {
- //System.out.println(j);
- }
- endTime = System.nanoTime();
- System.out.println("Using [int j = list.size(); j > 0 ; j--] :: " + (endTime - startTime) + " ms");
- }
- public static void main(String[] args) {
- new LoopPerformance().testLoopPerformance();
- }
- }
输出结果:
For each loop :: 48459306 msUsing collection.size() :: 13065838 ms
Using [int size = list.size(); int j = 0; j < size ; j++] :: 12495 ms
Using [int j = list.size(); j > 0 ; j--] :: 9371 ms
显然,style 1 时间消耗最大,随后是style2。而style 3 和tyle 4的性能差别不大,可以考虑这两者是一样的。为什么会有这样的结果呢?
style 3 和style 4它们都采用了collection集合的初始值,然后,在循环中用到。唯一的区别在于使用上,一个是作为状态比较,而另一个则作为变量的初始值。style 2使用size()作为循环判断的标准,每次作比较的时,它都会被调用一次。尽管JVM优化了内联调用以及其他优化,但是,多为大量的调用,必然会花费不必要的时间。需要知道,这样编码,在机器上执行的代码语句(字节码)更多。style 4 是最花费性能的,原因是它内部使用循环的迭代iterator 形式。创建interator和调用interator.get() 上花费很多的时间。
style 3 和style 4它们都采用了collection集合的初始值,然后,在循环中用到。唯一的区别在于使用上,一个是作为状态比较,而另一个则作为变量的初始值。style 2使用size()作为循环判断的标准,每次作比较的时,它都会被调用一次。尽管JVM优化了内联调用以及其他优化,但是,多为大量的调用,必然会花费不必要的时间。需要知道,这样编码,在机器上执行的代码语句(字节码)更多。style 4 是最花费性能的,原因是它内部使用循环的迭代iterator 形式。创建interator和调用interator.get() 上花费很多的时间。
- 比较Java循环的性能
- 深度比较Java循环的性能
- Java for循环和foreach循环的性能比较
- Java for循环和foreach循环的性能比较
- PHP与JAVA循环性能比较
- for 循环嵌套性能的比较
- 三种循环的性能比较
- for 循环性能比较 提高for循环的效率
- java基础复习四:for与foreach的循环性能比较
- java for/foreach/while 3种循环性能比较
- Foreach循环及For性能及使用上的比较
- java 中for循环的性能测试
- Scala和Java的循环性能对比
- .Net和Java的执行性能比较
- Java里多个Map的性能比较
- java 几个Map的性能比较
- Java不同压缩算法的性能比较
- Java不同压缩算法的性能比较
- 织梦单页 试图字段
- [教程]华为U8150民间ROM简单实用的刷机教程(卡刷图解)
- c++全局变量,多模块使用
- 设计之道
- Davinci DM6446 Linux 内核分析—— gpio.c
- 比较Java循环的性能
- iis配置错误
- 六个维度:简洁性
- 程序员的趣事汇总
- Davinci DM6446 Linux 内核分析—— clock.c
- cpp文件和.h文件
- VC++找Bug
- jsp自定义标签技术(原理和代码实现以及平台搭建)
- Bean的生命周期