我在我的Java类中使用GroovyClassLoader来解析某个(理想情况下很复杂的)groovy文件(将在下一步执行):
在MyClass.java中调用
final Class parsedClass = groovyClassLoader.parseClass(groovyFile);
知道:
GroovyFile.groovy导入
import com.my.import.one.Import1DTO
import com.my.import.two.Import2DTO
import com.my.import.three.Import3DTO
import com.my.import.four.Import4DTO
import com.my.import.five.Import5DTO
当调用 parseClass 方法时,此异常会引发:
例外
unable to resolve class com.my.import.one.Import1DTO;
unable to resolve class com.my.import.two.Import2DTO;
unable to resolve class com.my.import.three.Import3DTO;
unable to resolve class com.my.import.four.Import4DTO;
unable to resolve class com.my.import.five.Import5DTO;
在解析基类之前,我是否可以在不解析每个导入类的情况下获得我期望的行为?
谢谢!
答案 0 :(得分:5)
以下是使用addClasspath()
上的GroovyClassLoader
方法的MyClass.java示例
import groovy.lang.GroovyClassLoader;
public class MyClass {
public static void main(String... args) {
GroovyClassLoader groovyClassLoader = new GroovyClassLoader();
// add "lib" to the classpath
groovyClassLoader.addClasspath("lib");
String groovyFile = "GroovyFile.groovy";
Class parsedClass = groovyClassLoader.parseClass(groovyFile);
System.out.println("class is " + parsedClass.toString());
}
}
我假设DTO是用Groovy编写的,我们使用“myimport”,因为“my.import.x”会因非法语法而失败。如果我们有一个像这样的“lib”目录,那么编译类:
lib/com/myimport/one/Import1DTO.groovy
lib/com/myimport/one/Import1DTO.class
lib/com/myimport/two/Import2DTO.groovy
lib/com/myimport/two/Import2DTO.class
并且GroovyFile.groovy存在于主目录中。 e.g。
import com.myimport.one.Import1DTO
import com.myimport.two.Import2DTO
println "hi there"
然后上面的Java代码适合我。
我在类路径上使用Groovy 2.2.1和groovy-all-2.2.1.jar(对于GroovyClassLoader)。