Java groovy如何提升代码运行效率
刚开始学groovy,知道了它会先变异成class 文件,然后再用jvm 执行。写了Hello World程序,查看它的编译文件,发现groovy的效率挺低的。不但编译文件的代码多,而且需要依赖很多groovy包,导致了不能够直接使用java 命令运行class文件
比较如下:
Java版Hello World,JavaTest.java
public class JavaTest { public static void main(String[] args){ System.out.println("Hello World!"); } }
编译后:JavaTest.class
public class JavaTest { public JavaTest() { } public static void main(String[] args) { System.out.println("Hello World!"); } }
Groovy版Hello World,GroovyTest.groovy
GroovyTest.groovy class GroovyTest { static void main(args){ println "Hello World!"; } }
编译后:GroovyTest.class
import groovy.lang.GroovyObject; import groovy.lang.MetaClass; import org.codehaus.groovy.runtime.callsite.CallSite; public class GroovyTest implements GroovyObject { public GroovyTest() { CallSite[] var1 = $getCallSiteArray(); MetaClass var2 = this.$getStaticMetaClass(); this.metaClass = var2; } public static void main(String... args) { CallSite[] var1 = $getCallSiteArray(); var1[0].callStatic(GroovyTest.class, "Hello World!"); } }
Groovy 升级版,GroovyTest.groovy
println("Hello World");
编译后:GroovyTest.class
import groovy.lang.Binding; import groovy.lang.Script; import org.codehaus.groovy.runtime.InvokerHelper; import org.codehaus.groovy.runtime.callsite.CallSite; public class GroovyTest extends Script { public GroovyTest() { CallSite[] var1 = $getCallSiteArray(); } public GroovyTest(Binding context) { CallSite[] var2 = $getCallSiteArray(); super(context); } public static void main(String... args) { CallSite[] var1 = $getCallSiteArray(); var1[0].call(InvokerHelper.class, GroovyTest.class, args); } public Object run() { CallSite[] var1 = $getCallSiteArray(); return var1[1].callCurrent(this, "Hello World"); } }
越高级的语言,封装的越多,开发简单效率低
越底层的语言,封装的越少,开发复杂效率高
所以如果追求效率的话,还是使用Java代码的好。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
关于Mybatis-Plus Wrapper是否应该出现在Servcie类中
最近在做代码重构,代码工程采用了Controller/Service/Dao分层架构,Dao层使用了Mybatis-Plus框架,本文带领大家学习Mybatis-Plus Wrapper应该出现在Servcie类中吗,需要的朋友可以参考下2023-05-05Java中的线程池ThreadPoolExecutor深入解析
这篇文章主要介绍了Java中的线程池ThreadPoolExecutor深入解析,线程池,thread pool,是一种线程使用模式,线程池维护着多个线程,等待着监督管理者分配可并发执行的任务,需要的朋友可以参考下2023-11-11
最新评论