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 и
парсинг скриптов в два раза. Когда цикл повторяется для
второй раз, и снова пытается разобрать groovyscript, что будет
происходят?
- Что произойдет во второй раз, когда будет создан другой объект.
Удастся ли загрузчику классов получить класс из classpath или
снова перекомпилировать снова?
- Когда запускается перекомпиляция, как Groovy узнает, что это за источник?
изменилось?