Gradle Exec 块不会将标准输出重定向到给定的输出流



我有这样的块:

task print() {
doLast {
println("stop-1")
println(getJavaVersion())
println("stop-3")
}
}
def getJavaVersion() {
def out = new ByteArrayOutputStream()
exec {
workingDir 'C:/Program Files/Java/jdk1.7.0_80/bin'
commandLine 'cmd', '/c', 'java', '-version'
standardOutput = out
}
println 'stop-2'
return out.toString()
}

我希望输出将打印在print任务的doLast块内,但它是在exec块之后打印的。

这是输出:

Executing tasks: [print]
Parallel execution with configuration on demand is an incubating feature.
> Task :gcUnicorn-core:print
stop-1
java version "1.7.0_80"
Java(TM) SE Runtime Environment (build 1.7.0_80-b15)
Java HotSpot(TM) 64-Bit Server VM (build 24.80-b11, mixed mode)
stop-2
stop-3
BUILD SUCCESSFUL in 0s
1 actionable task: 1 executed

正如您所看到的,输出流是空的。

我查阅了Gradle的文档和我发现的许多例子,但没有运气解决它

渐变:4.10.2,窗口:7,jdk1.8.0_192

谢谢你的建议。

实际上java -version将消息打印到标准错误而不是标准输出(stdout(,因此请尝试:

errorOutput = out

最新更新