func test() {
	num1 := 10
	num2 := 0
	result := num1 / num2
	fmt.Println("result", result)
}
func main() {
	test()
	for {
		fmt.Println("运行完毕!   main 下面的代码")
		time.Sleep(time.Second)
	}
}

- 在默认情况下,当发生错误后(panic) ,程序就会退出(崩溃.)
- 如果我们希望:当发生错误后,可以捕获到错误,并进行处理,保证程序可以继续执行。还可
 以在捕获到错误后,给管理员一个提示(邮件,短信。。。)
- 这里引出我们要将的错误处理机制
基本说明
- Go 语言追求简洁优雅,所以,Go 语言不支持传统的 try…catch…finally 这种处理。
- Go 中引入的处理方式为:defer, panic, recover
- 这几个异常的使用场景可以这么简单描述:Go 中可以抛出一个 panic 的异常,然后在 defer 中
 通过 recover 捕获这个异常,然后正常处理
 使用 defer+recover 来处理错误
func test() {
	defer func() {
		err := recover()
		if err != nil {
			fmt.Println("错误信息:", err)
		}
	}()
	num1 := 10
	num2 := 0
	result := num1 / num2
	fmt.Println("result", result)
}
func main() {
	test()
	for {
		fmt.Println("运行完毕!   main 下面的代码")
		time.Sleep(time.Second)
	}
}

 进行错误处理后,程序不会轻易挂掉,如果加入预警代码,就可以让程序更加的健壮。看一个
 案例演示:

自定义错误
 自定义错误的介绍
 Go 程序中,也支持自定义错误, 使用 errors.New 和 panic 内置函数。
- errors.New(“错误说明”) , 会返回一个 error 类型的值,表示一个错误
- panic 内置函数 ,接收一个 interface{}类型的值(也就是任何值了)作为参数。可以接收 error 类
 型的变量, 输出错误信息, 并退出程序.
 案例说明
package main
import (
	"errors"
	"fmt"
	"time"
)
func main() {
	Test2()
	for {
		fmt.Println("运行完毕!   main 下面的代码")
		time.Sleep(time.Second)
	}
}
// 读取文件,传入的参数名称错误返回一个自定义的错误
func ReadConfig(f string) (err error) {
	if f == "Config.init" {
		fmt.Println("读取文件成功!")
		return nil
	} else {
		return errors.New("文件名不是Config.init")
	}
}
func Test2() {
	err := ReadConfig("Config.init00")
	if err != nil {
		panic("取出文件错误。。。")
		fmt.Println("终止运行了!")
	} else {
		fmt.Println("Test2  继续执行")
	}
}

正确文件
 



















