如果恐慌(在Go中)我希望从函数返回错误:
func getReport(filename string) (rep report, err error) {
rep.data = make(map[string]float64)
defer func() {
if r := recover(); r != nil {
fmt.Println("Recovered in f", r)
err, _ = r.(error)
return nil, err
}
}()
panic("Report format not recognized.")
// rest of the getReport function, which can try to out-of-bound-access a slice
...
}
我似乎误解了恐慌和推迟的概念。有人可以开导我吗?
答案 0 :(得分:57)
在延迟函数中,您可以更改返回的参数,但不能返回新集。因此,对所拥有的内容进行简单的更改将使其发挥作用。
你写的内容还有另外一个问题,就是你用string
进行了抨击,但在你的类型断言中期待error
。
以下是两个(Play)
的修复方法defer func() {
if r := recover(); r != nil {
fmt.Println("Recovered in f", r)
// find out exactly what the error was and set err
switch x := r.(type) {
case string:
err = errors.New(x)
case error:
err = x
default:
err = errors.New("Unknown panic")
}
// invalidate rep
rep = nil
// return the modified err and rep
}
}()
答案 1 :(得分:3)
看看这个
if (n != 0) {
for (i=0 ; i<n ; i++) {
if (a[i]>a[p]) p=i; # first select the rank
}
if (p != n-1) { # then exchange elements
int tmp = a[p];
a[p] = a[n-1];
a[n-1] = tmp;
}
答案 2 :(得分:2)
func TestReturnFromPanic(t *testing.T) {
fn := func(filename string) (rep string, err error) {
defer func() {
if r := recover(); r != nil {
err = fmt.Errorf("panic in getReport %s", r)
}
}()
return filename[100:], nil
}
t.Log(fn(``))
}
命名返回参数err
是窍门。