go 捕获处理error

版权声明: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)
}

猜你喜欢

转载自blog.csdn.net/aaaadong/article/details/90737142