Java For循环效率测试

本文通过两个Java程序对比,展示了在for循环中加入简单条件判断导致执行时间显著增加的现象,并探讨了可能的原因。

很奇怪的结果!!!!


测试程序如下

public class Main {

	public static void main(String[] args){

        	long ti = System.currentTimeMillis();
        	for(int i=Integer.MIN_VALUE;i<Integer.MAX_VALUE;i++){
        	    if(i==i) continue;
        	}
        	System.out.println(System.currentTimeMillis()-ti);
        	

        	ti = System.currentTimeMillis();
        	for(int i=Integer.MIN_VALUE;i<Integer.MAX_VALUE;i++){
        	    continue;
        	}
        	System.out.println(System.currentTimeMillis()-ti);
	}

}

输出结果
6
1320


问题1:

在for循环中加入判断后,循环执行的时间竟然差这么多。。


以上是问题,看下面这个测试,你会发现更有意思

public class Main {

	public static void main(String[] args){
        	
        	long ti = System.currentTimeMillis();
        	long c = 0;
        	for(int i=Integer.MIN_VALUE;i<Integer.MAX_VALUE;i++){
        	    c++;
        	    if(i==i) continue;
        	}
        	System.out.println(System.currentTimeMillis()-ti + "  "+c);
        	
        	ti = System.currentTimeMillis();
        	c=0;
        	for(int i=Integer.MIN_VALUE;i<Integer.MAX_VALUE;i++){
        	    c++;
        	    continue;
        	}
        	System.out.println(System.currentTimeMillis()-ti+ "  "+c);
	}

}
同样输出

93  4294967295
7847  4294967295

仅仅是在循环内做了一次++操作,耗时竟然增加了近10倍!

不得不说,java!你的运行效率实在是惨不忍睹。。。。

java版本:  javac 1.7.0_25



求解释:

在for循环中加入判断与不加判断,执行时间相差为什么会相差200倍?!

-------------------------------------------------------------------------------------------------

今天又测试一次,java版本不知道什么时候变成了这个样子: javac 1.7.0_55    结果不再和上次测试一样,看来上次是遇到bug了。。  而且也不知道java什么时候自己升级的。。


### Java 中 `for` 循环的使用方法 #### 传统 `for` 循环Java中,最常用的循环之一就是传统的`for`循环。此类型的循环允许程序员指定初始化表达式、测试条件和更新操作,在每次迭代结束时执行。 语法如下: ```java for (initialization; condition; update) { // 执行代码块 } ``` 下面是一个简单的例子,展示如何打印从1到5的整数[^3]: ```java public class ForLoopExample { public static void main(String[] args) { for (int i = 1; i <= 5; i++) { System.out.println(i); } } } ``` 这段程序会依次输出数字1至5。 #### 倒序遍历数组 当涉及到倒序访问数据结构如数组的时候,可以通过调整初始值和增量方向实现逆向遍历。这里给出一段用来反转显示字符串字符的例子[^2]: ```java String str = "hello"; char[] charArray = str.toCharArray(); for (int j = charArray.length - 1; j >= 0; --j){ System.out.print(charArray[j]); } // 输出 olleh ``` 该片段展示了怎样利用`for`循环来逐一遍历并按相反顺序输出给定字符串中的每一个字符。 #### 嵌套 `for` 循环及其性能影响 有时为了完成某些复杂的逻辑运算可能需要用到多层嵌套形式的`for`循环。然而需要注意的是,随着层数增加,算法的时间复杂度也会相应增长,可能导致效率低下甚至造成严重的性能瓶颈问题[^4]。 例如,两个相互独立变量之间的组合计算就可以采用双重循环的方式解决: ```java for(int row=0 ;row<rowsCount; ++row){ for(int col=0;col<colsCount;++col){ // 对应位置的操作... } } ``` 但是应当谨慎对待此类设计模式的选择,并考虑是否有更高效的替代方案可用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值