版权声明:by DongBao https://blog.csdn.net/aaaadong/article/details/90737142
package main
import (
"errors"
"fmt"
)
func PanicError(p interface{}) (err error) {
//捕获 and 恢复 panic.
/*注意defer延迟执行的函数可以修改外围函数“PanicError”的命名返回值.
*通过调用recover捕获panic并转化为error. 也许有人打算在main函数中放一个下面这个defer语句,用于捕获程序中的一切panic异常,
*建立最后一道防火墙,从而使程序避免崩溃运行下去, 但很不幸, 当main函数的defer延迟函数被执行时,也就意味着main函数要退出了,
*此时再捕获panic恢复程序,意义还有多大呢;不过我们有办法克服, 建立一个像“PanicError”这样的一个外围封装函数,在这个函数中,
*建立最后一道防火墙,就像此处例子代码中所做的一样, 将panic封闭在自己的包内, 不允许蔓延传染给其它包, 包与包之间只通过error传递
*结果状态.
*/
defer func() {
if r := recover(); r != nil {
fmt.Println("Recovered in PanicError", r)
//check exactly what the panic was and create error.
switch x := r.(type) {
case string:
err = errors.New(x)
case error:
err = x
default:
err = errors.New("Unknow panic")
}
}
}()
panic(p)
return nil
}
func main() {
//logic code , panic here.
//panic("i am string")
//panic(errors.New("i am error"))
fmt.Println(PanicError("i am string"))
fmt.Println(PanicError(4))
fmt.Println(errors.New("i am error"))
fmt.Println("panic restore now, continue.")
}
自己写的一种,尽量避免panic的情况
20190610更新
第二版,利用开源工具包处理error
go get github.com/pkg/errors
package main
import (
"fmt"
"github.com/pkg/errors"
)
func main() {
err := createError("this is a simple error", "this is error description")
if err != nil {
fmt.Println(err.Error())
}
}
func createError(errorName string, errorDescription string) error {
return errors.Wrap(errors.New(errorName), errorDescription)
}