调试 Go 的 exec.Command 中的“退出状态 1”错误
执行外部命令时遇到神秘的“退出状态 1”错误使用 Golang 的 exec.Command,查明确切原因可能是一项艰巨的任务。本简短指南将提供有效排除错误的见解。
使用 Stderr 增强错误消息
默认情况下,exec.Command 仅捕获标准输出 (stdout)运行命令。要检索更详细的错误消息,您可以利用 exec.Command 结构的 Stderr 属性。具体方法如下:
cmd := exec.Command("find", "/", "-maxdepth", "1", "-exec", "wc", "-c", "{}", "\") var out bytes.Buffer var stderr bytes.Buffer cmd.Stdout = &out cmd.Stderr = &stderr
现在,当执行命令并发生错误时,错误消息将写入 stderr 缓冲区,而不是通用的“退出状态 1”。
示例
考虑以下代码snippet:
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())
执行后,代码将显示以下详细错误消息:
exit status 1: find: -exec: no terminating ";" or "+"
其他注意事项
值得注意某些命令可能不遵守将错误写入 stderr 的约定。某些命令可能会将错误打印到 stdout,而其他命令可能会将错误打印到 stderr,但仍返回成功退出状态 (0)。因此,可能需要调整代码以满足您正在执行的特定命令。
以上是为什么我的 Go 代码在使用 exec.Command 时返回'退出状态 1”?的详细内容。更多信息请关注PHP中文网其他相关文章!