罪魁祸首是您的
copyJarToBin任务。做的时候
task copyJarToBin { copy { from 'build/libs/GradleJarProject.jar' into "d:/tmp" }}您可以在配置期间使用该
copy方法复制jar
。(请参阅gradle用户指南,网址为https://docs.gradle.org/current/userguide/userguide_single.html#sec:build_phases了解构建生命周期)您想要在执行阶段(执行以下操作)运行实际的复制操作任务)。
解决该问题的
copy一种方法是将方法的调用移到doLast块中:
task copyJarToBin { doLast { copy { from 'build/libs/GradleJarProject.jar' into "d:/tmp" } }}这种方法的问题是,每次执行任务时,即使文件没有更改,您也不会享受gradles增量构建功能和每次复制该文件的好处。
编写copyJarToBin任务的一种更好且更惯用的方式是更改任务实现以使用
Copy任务类型:
task copyJarToBin(type: Copy) { from 'build/libs/GradleJarProject.jar' into "d:/tmp"}我们甚至可以利用gradle的自动装配功能来改进此代码段。您可以将一个任务的输出声明为另一个任务的输入。因此,无需编写`build / libs /
GradleJarProject.jar’,您只需执行以下操作:
task copyJarToBin(type: Copy) { from createJar // shortcut for createJar.outputs.files into "d:/tmp"}现在,您无需担心任务排序,因为gradle知道
createJar必须先执行
copyJarToBin任务,然后才能执行任务。



