我有一種快速運(yùn)行 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 stringif 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)}運(yùn)行它會產(chǎn)生一個 SIGSEGV。但是,當(dāng)我發(fā)表評論時,對它的第二次調(diào)用runcmd正常運(yùn)行(返回Unknown OS! Exiting without running! exit status 3)。我是新手,所以我并不真正理解 nil 指針取消引用錯誤,更不用說為什么它只會在第二次調(diào)用時發(fā)生。
2 回答

函數(shù)式編程
TA貢獻(xiàn)1807條經(jīng)驗 獲得超9個贊
err.Error()當(dāng)沒有錯誤 ( ) 時,您總是會返回,err == nil這會因零指針取消引用而失敗。你應(yīng)該做
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
}
進(jìn)而
if exitcode != nil {

森欄
TA貢獻(xiàn)1810條經(jīng)驗 獲得超5個贊
這是因為這一行而發(fā)生的:
return o.String(), e.String(), err.Error()
如果您運(yùn)行的是 CentOS,則err := cmd.Run()
不會返回任何錯誤。然后err
會nil
。但在return
排隊你回來了err.Error()
。您不能使用對 nil 指針的訪問。所以,你收到了這個錯誤。
- 2 回答
- 0 關(guān)注
- 152 瀏覽
添加回答
舉報
0/150
提交
取消