在Golang中运行exec.Command时如何调试“退出状态1”错误

当我运行以下代码时:

cmd := exec.Command("find", "/", "-maxdepth", "1", "-exec", "wc", "-c", "{}", "\\")

var out bytes.Buffer

cmd.Stdout = &out

err := cmd.Run()

if err != nil {

fmt.Println(err)

return

}

fmt.Println("Result: " + out.String())

我收到此错误:

退出状态1

但是,这对调试错误的确切原因没有帮助。

如何获得更详细的信息?

回答:

解决方案是使用StderrCommand对象的属性。可以这样完成:

cmd := exec.Command("find", "/", "-maxdepth", "1", "-exec", "wc", "-c", "{}", "\\")

var out bytes.Buffer

var stderr bytes.Buffer

cmd.Stdout = &out

cmd.Stderr = &stderr

err := cmd.Run()

if err != nil {

fmt.Println(fmt.Sprint(err) + ": " + stderr.String())

return

}

fmt.Println("Result: " + out.String())

运行上面的代码,可以清楚地说明问题所在:

退出状态1:查找:-exec:不终止“;” 或“ +”

在上面的代码中,我们希望在发生错误的情况下,消息将被打印到stderr,并且命令将返回非零的错误代码。这或多或少是标准的。

但是,如下面@snorberhuis所述,某些命令将错误输出到stdout。其他命令可能会打印到stderr,但返回错误代码0(在这种情况下errnil)。并且在stderr中存储消息并不一定意味着存在错误(ffmpeg工具经常这样做)。

因此,基本上,您可能需要调整上面的代码以适应您期望的命令。

以上是 在Golang中运行exec.Command时如何调试“退出状态1”错误 的全部内容, 来源链接: utcz.com/qa/412908.html

回到顶部