해결된 질문
작성
·
26
0
안녕하세요 강사님
task firstTask {
println "Hello World"
doFirst(){
println "First action!!"
}
doLast(){
println "Last action!!"
}
}
task secondTask {
doFirst(){
println "First action in secondTask"
}
doLast(){
println "Last action in secondTask"
}
}
위와 같이 task를 작성하였습니다!
secondTask를 작성할 때는 Hello World를 지운 상태로 실행을 했는데도
gradle sT를 이용해서 sT를 실행하는 터미널 명령어를 사용했습니다!
> Configure project :
Hello World
가 터미널에 출력되는 이유를 알 수 있을까요??
답변 2
1
안녕하세요 hong090992님,
Gradle에서는 스크립트를 실행할 때 설정 단계(configuration phase)와 실행 단계(execution phase)로 나누어 작업을 처리합니다.
이 코드로 설명을 드리자면 ...
설정 단계: Gradle이 빌드 파일을 처음 처리할 때, 모든 작업이 설정됩니다. 이 단계에서 task 블록 안에 직접 작성된 코드(println "Hello World")는 해당 작업을 실행할지 여부와 관계없이 즉시 실행됩니다.
실행 단계: 실제로 특정 작업(secondTask 등)을 실행할 때는, 그 작업 내의 doFirst와 doLast 블록만 실행됩니다. 이 블록들은 해당 작업이 실행될 때 수행될 액션을 정의합니다.
따라서 예제 코드에서는 ...
firstTask 내부의 println "Hello World"는 설정 단계에서 실행되기 때문에, Gradle이 빌드 파일을 처리하는 즉시 출력됩니다. firstTask를 실행할지 여부와 관계없이 설정 단계에서 이미 출력이 되는 것이죠.
secondTask를 실행할 때는 doFirst와 doLast 블록의 내용만 실행되고, firstTask의 println "Hello World"는 이미 설정 단계에서 출력이 완료된 상태입니다.
0