0

我正在尝试加载在构建期间编译并作为 .class 文件放置在类路径中的类。为此,我尝试了

GroovyClassLoader gos = new GroovyClassLoader();

gos.loadClass("className");

这将成功加载 java 代码中的类文件,但它使用 AppClassLoader 来加载这个而不是 GroovyClassLoader。

我了解 GroovyClassLoader 在内部使用 AppClassLoader 找到它。但有一个区别:

正如gos.parseClass(string)将给我们一个从 GroovyClassLoader 解析的类。

在第二种情况(parseClass)中实例化类文件时,我们可以委托设置委托,但在第一种情况(loadClass)中,我们没有任何委托。

执行 loadClass 或通过 GroovyClassLoader 加载类文件的任何方式后如何设置委托。

负载等级

4

1 回答 1

0

Groovy Compiler 编译 groovy 文件(HelloWorld.dsl)并将它们放在类路径中,创建具有相同名称的 .class 文件(HelloWorld.class)。默认情况下编译的类文件(打开字节码)具有与类文件同名的类(HelloWorld)。

这个类将从 Script 中得到扩展。现在,如果您尝试使用 加载这个类文件 gos.loadClass("HelloWorld").newInstance(),它将给我们一个 Script 对象,我们将无法为 Script 对象设置委托。它也不会被转换成 DelegatingScript。

要使您的编译类从 DelegatingScript 扩展,请将其添加到您的 dsl 文件顶部@groovy.transform.BaseScript DelegatingScript delegatingScript 。Groovy 编译器会理解这一点,并使类文件从 DelegatingScript 而不是之前的 Script 扩展。

现在,当您尝试使用 加载类时gos.loadClass("HelloWorld").newInstance(),它会给出一个 DelegatingScript 对象而不是 Script 对象。对于这个对象,我们可以设置委托并运行脚本。

如果您正在使用 parseClass,要使用委托,我们需要将 ScriptBaseClass 设置为 DelegatingScript 到 compilerConfiguration。现在如果你尝试 gos.parseClass(dslText).newInstance(),它会直接给出一个 DelegatingScript 对象,我们可以设置一个委托并运行脚本。

于 2021-07-09T15:00:23.577 回答