在其他語言中的 try{}catche(){} 結構通常是在入口函數下加上, 然后實現業務邏輯時出現異常就直接trhow Exception 就行那么在 go 中, 有兩種方式, 一種是:func A(a string) (res string, err error) {
res, err = B(a) // 實際中的 A 函數調用不止一個 B, 還有 C, D, E 什么的的
if err != nil { return "", err
} return res, nil}func B(b string) (res string, err error) { if b == "a" { return "hello " + b, nil
} else { return "", errors.New("params need a")
}
}這種將 error 一層層向外翻還是說通過 panic/recover的方式返回func A(a string) (res string, err error) { defer func() { if err := recover(); err != nil {
fmt.Println(err)
}
}()
res = B(a) return res, err
}func B(b string) (res string) { if b == "a" { return "hello " + b
} else { panic("params need a")
}
}我的疑問是:這兩種方式的使用場景是什么?如果濫用 panic 會造成什么后果?
- 1 回答
- 0 關注
- 948 瀏覽
添加回答
舉報
0/150
提交
取消