源测试代码如下
public class ForEachTest { public void test4Iterate(Iterable<String> strings) { for (String str : strings) { System.out.println(str); } } public void test4Array(String[] strings) { for (String str : strings) { System.out.println(str); } } }
执行编译命令
javac ForEachTest.java
使用idea查看反编的Java文件
import java.util.Iterator; public class ForEachTest { public ForEachTest() { } public void test4Iterate(Iterable<String> var1) { Iterator var2 = var1.iterator(); while(var2.hasNext()) { String var3 = (String)var2.next(); System.out.println(var3); } } public void test4Array(String[] var1) { String[] var2 = var1; int var3 = var1.length; for(int var4 = 0; var4 < var3; ++var4) { String var5 = var2[var4]; System.out.println(var5); } } }
执行指令查看对应的汇编指令
javap -c ForEachTest.class
Compiled from "ForEachTest.java" public class ForEachTest { public ForEachTest(); Code: 0: aload_0 1: invokespecial #1 // Method java/lang/Object."<init>":()V 4: return public void test4Iterate(java.lang.Iterable<java.lang.String>); Code: 0: aload_1 1: invokeinterface #2, 1 // InterfaceMethod java/lang/Iterable.iterator:()Ljava/util/Iterator; 6: astore_2 7: aload_2 8: invokeinterface #3, 1 // InterfaceMethod java/util/Iterator.hasNext:()Z 13: ifeq 36 16: aload_2 17: invokeinterface #4, 1 // InterfaceMethod java/util/Iterator.next:()Ljava/lang/Object; 22: checkcast #5 // class java/lang/String 25: astore_3 26: getstatic #6 // Field java/lang/System.out:Ljava/io/PrintStream; 29: aload_3 30: invokevirtual #7 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 33: goto 7 36: return public void test4Array(java.lang.String[]); Code: 0: aload_1 1: astore_2 2: aload_2 3: arraylength 4: istore_3 5: iconst_0 6: istore 4 8: iload 4 10: iload_3 11: if_icmpge 34 14: aload_2 15: iload 4 17: aaload 18: astore 5 20: getstatic #6 // Field java/lang/System.out:Ljava/io/PrintStream; 23: aload 5 25: invokevirtual #7 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 28: iinc 4, 1 31: goto 8 34: return }
由反编类和汇编指令可以看到对于Iterable类,是通过其迭代方法执行for each,而对于数组是通过传统的for循环方式执行迭代
因为集合类的for each是基于迭代器循环的,所以根据迭代器实现的不同,for each的性能也会不同
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Spring HandlerInterceptor实现原理代码解析,包括了Spring HandlerInterceptor实现原理代码解析的使用技巧和注意事项,需要的朋友参考一下 HandlerInterceptor 在这里看到这个HandlerExecutionChain对interceptor的调用,在这里深入看一下。 HandlerExecutionChain 就是一个类,绑
本文向大家介绍Java SPI机制原理及代码实例,包括了Java SPI机制原理及代码实例的使用技巧和注意事项,需要的朋友参考一下 SPI的全名为:Service Provider Interface,大多数开发人员可能不熟悉,因为这个是针对厂商或者插件的。在java.util.ServiceLoader的文档里有比较详细的介绍。 简单的总结下 Java SPI 机制的思想。我们系统里抽象的各个模
本文向大家介绍Python代码块及缓存机制原理详解,包括了Python代码块及缓存机制原理详解的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Python代码块及缓存机制原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.相同的字符串在Python中地址相同 2.代码块: 所有的代码都需要依赖代码块执行。 一个模块,一个函
本文向大家介绍Django权限机制实现代码详解,包括了Django权限机制实现代码详解的使用技巧和注意事项,需要的朋友参考一下 本文研究的主要是Django权限机制的相关内容,具体如下。 1. Django权限机制概述 权限机制能够约束用户行为,控制页面的显示内容,也能使API更加安全和灵活;用好权限机制,能让系统更加强大和健壮。因此,基于Django的开发,理清Django权限机制是非常必要的。
本文向大家介绍MyBatis缓存实现原理及代码实例解析,包括了MyBatis缓存实现原理及代码实例解析的使用技巧和注意事项,需要的朋友参考一下 一、一级缓存(本地缓存) sqlSession级别的缓存。一级缓存是一直开启的;SqlSession级别的一个Map与数据库同一次会话期间查询到的数据会放在本地缓存中。以后如果需要获取相同的数据,直接从缓存中拿,没必要再去查询数据库; 一级缓存失效
本文向大家介绍详解Java动态代理的实现机制,包括了详解Java动态代理的实现机制的使用技巧和注意事项,需要的朋友参考一下 一、概述 代理是一种设计模式,其目的是为其他对象提供一个代理以控制对某个对象的访问,代理类负责为委托类预处理消息,过滤消息并转发消息以及进行消息被委托类执行后的后续处理。为了保持行为的一致性,代理类和委托类通常会实现相同的接口。 按照代理的创建时期,代理类可分为两种: