gpt4 book ai didi

Golang SIGSEGV on *second* call only

转载 作者:数据小太阳 更新时间:2023-10-29 03:31:29 25 4
gpt4 key购买 nike

我有一个快速运行 shell 命令的方法:

func runcmd(c string, arg ...string) (string, string, string) {
var o bytes.Buffer
var e bytes.Buffer
cmd := exec.Command(c, arg...)
cmd.Stdout = &o
cmd.Stderr = &e
err := cmd.Run()
return o.String(), e.String(), err.Error()
}

在我的主要有以下代码:

func main() {

ver, _, exitcode := runcmd("rpm", "-q", "--queryformat", "%{VERSION}", "redhat-release")
var dist string
if exitcode != "" {
ver, _, exitcode = runcmd("rpm", "-q", "--queryformat", "%{VERSION}", "centos-release")
if exitcode != "" {
fmt.Println("Unknown OS! Exiting without running!")
os.Exit(3)
}
dist = "CentOS"
} else {
dist = "Redhat/Redhat derivative"
}

fmt.Printf("System is %s %s.\n", dist, ver)
}

运行它会产生一个 SIGSEGV。但是,当我评论对 runcmd 的第二次调用时,它会正常运行(返回 Unknown OS!Exiting without running!exit status 3)。我是新手,所以我一开始并不真正理解 nil 指针取消引用错误,更不用说为什么它只会在第二次调用时发生。

最佳答案

您总是返回 err.Error(),当没有错误时 (err == nil),此操作失败并返回 nil 指针取消引用。你应该做的

func runcmd(c string, arg ...string) (string, string, error) {
e bytes.Buffer
cmd := exec.Command(c, arg...)
cmd.Stdout = &o
cmd.Stderr = &e
err := cmd.Run()
return o.String(), e.String(), err
}

然后

if exitcode != nil {

关于Golang SIGSEGV on *second* call only,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53214932/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com