官术网_书友最值得收藏!

  • Groovy 2 Cookbook
  • Andrey Adamovich Luciano Fiandesio
  • 472字
  • 2021-07-23 15:57:19

Running Groovy with invokedynamic support

One of the biggest improvements introduced in Groovy 2.0 is the support for the invokedynamic instruction. The invokedynamic is a new JVM instruction available in Java 7, which allows easier implementation and promises increased speed and efficiency of dynamic languages (for example, Groovy).

Dynamic languages generate a bytecode that often necessitates a number of JVM method invocations to perform a single operation. Furthermore, reflection and dynamic proxies are used extensively, which comes with a costly performance toll. Also, the JIT (Just-In-Time) compiler that helps to improve the runtime performance of a JVM, cannot work its magic by applying optimization to the bytecode because it lacks information and patterns, which are normally possible to optimize. The new bytecode instruction, invokedynamic, is able to mitigate partially these issues, including support for better JIT optimization.

In this recipe, we will show how to run Groovy with the invokedynamic (also known as indy) support and Java 7.

Getting ready

The invokedynamic support is a compile-time and runtime feature only. In other words, a developer cannot use it from within the source code. What invokedynamic brings to Groovy 2.0 (and even more to 2.1) is basically improved runtime performance.

How to do it...

As explained in the introduction, Java 7 is the required version of the JVM to compile Groovy code that leverages the invokedynamic instruction:

  1. Make sure that Java 7 is your current JVM. Type java -version and confirm that the output mentions Version 7:
    java version "1.7.0_25"
    
  2. The following steps will let us fully enable the indy support in your Groovy distribution. First of all rename or remove all the JAR files starting with groovy- in the lib directory of your Groovy 2.x home directory.
  3. Replace them with the files in the indy directory located in the root of the Groovy distribution folder.
  4. Remove the -indy classifier from the JAR names.
  5. Finally, invoke either groovy or the groovyc compiler with the --indy flag to execute your code:
    groovy --indy my_script.groovy
    

There's more...

It is important to note that if the --indy flag is omitted, the code will be compiled without the invokedynamic support, even if Java 7 is used and the Groovy JAR files have been replaced.

The performance gain introduced by the new JVM instruction greatly varies depending on a numbers of factors, including the actual JVM version and the type of code that is optimized. JVM support for the invokedynamic instruction improves at each version. The upcoming Java 8 will use invokedynamic to support lambda functions, so it is very likely that newer JVMs will offer even greater optimization. Given the current state of things, some benchmarks that we have run have shown an improvement of around 20 percent when given the same code compiled with the invokedynamic instruction enabled.

See also

主站蜘蛛池模板: 平乐县| 汪清县| 浪卡子县| 修水县| 正蓝旗| 吉林市| 双辽市| 津南区| 金平| 北川| 四子王旗| 莱阳市| 全椒县| 汉寿县| 龙川县| 宁乡县| 安达市| 凤山县| 清新县| 永泰县| 邯郸县| 开封县| 宁城县| 剑河县| 泸西县| 阿图什市| 馆陶县| 博爱县| 磴口县| 建宁县| 安新县| 晋江市| 临汾市| 礼泉县| 饶阳县| 璧山县| 四子王旗| 团风县| 治县。| 孟村| 二手房|