Понимание поведения GroovyClassloader,
ScriptEngineManager factory = new ScriptEngineManager();
ScriptEngine engine = factory.getEngineByName("groovy");
GroovyScriptEngineImpl groovyEngineImpl = (GroovyScriptEngineImpl) engine;
в петле,
for (int i = 0; i < 10; i++) {
long startTime = System.currentTimeMillis();
classLoader = new GroovyClassLoader(groovyEngineImpl.getClassLoader().getParent());
fileName = fileName + i;
Class groovyClass = classLoader.parseClass(s,fileName);
long endTime = System.currentTimeMillis();
System.out.println("Total elapsed time in execution o " + (endTime-startTime));
startTime = System.currentTimeMillis();
groovyClass = classLoader.parseClass(s,fileName);
endTime = System.currentTimeMillis();
System.out.println("Second Time Total elapsed time in execution o " + (endTime-startTime));
}
У меня есть пара вопросов по приведенному выше коду:
- В цикле for я создаю новый объект groovyclassloder и дважды анализирую скрипт groovy. Что произойдет, когда цикл повторится во второй раз и снова попытается проанализировать groovyscript?
- Что произойдет во второй раз, когда будет создан другой объект. Сможет ли загрузчик классов получить класс из пути к классам или снова перекомпилировать его?
- Когда запускается перекомпиляция, как groovy узнает, что исходный код изменен?