当前位置: 首页 > article >正文

【Go 】异常处理

1. Go 语言错误处理基础

  • Go 语言尽量避免使用异常,推荐使用 返回错误 让调用者处理。
  • Go 语言标准库提供 error 接口:
    type error interface {
        Error() string
    }
    
  • errors.New("错误信息") 创建错误对象。
package main

import (
	"errors"
	"fmt"
)

func hello(name string) error {
	if len(name) == 0 {
		return errors.New("NameError: name is empty!!")
	}
	fmt.Println("hello !", name)
	return nil
}

func main() {
	err := hello("")
	if err != nil {
		fmt.Println("发生错误:", err)
	}
}

2. 自定义错误

  • errors.New() 生成错误信息
  • fmt.Errorf() 格式化错误信息
  • 返回错误让调用者决定如何处理
package main

import (
	"errors"
	"fmt"
)

func divide(a, b int) (int, error) {
	if b == 0 {
		return 0, errors.New("除数不能为0")
	}
	return a / b, nil
}

func main() {
	result, err := divide(10, 0)
	if err != nil {
		fmt.Println("计算错误:", err)
	} else {
		fmt.Println("计算结果:", result)
	}
}

3. panicrecover

  • panic 类似于 Python 的 raise,会让程序崩溃。
  • recover 用于捕获 panic,防止程序崩溃。
  • recover 必须在 defer 语句中调用,否则无效。
package main

import "fmt"

func safeFunction() {
	defer func() {
		if r := recover(); r != nil {
			fmt.Println("捕获到 panic:", r)
		}
	}()
	fmt.Println("执行函数...")
	panic("故意触发 panic") // 触发 panic
}

func main() {
	safeFunction()
	fmt.Println("程序继续执行...")
}

4. panic 与数组越界

  • 数组访问越界会引发 panic,所以要提前检查索引范围。
package main

import (
	"errors"
	"fmt"
)

func getElement(index int) (int, error) {
	arr := [3]int{10, 20, 30}
	if index < 0 || index >= len(arr) {
		return 0, errors.New("索引超出范围")
	}
	return arr[index], nil
}

func main() {
	elem, err := getElement(3)
	if err != nil {
		fmt.Println("错误:", err)
	} else {
		fmt.Println("元素:", elem)
	}
}

5. defer 关键字

  • defer 语句用于延迟执行,常用于 释放资源、错误恢复等场景
  • 多个 defer先进后出(LIFO) 执行。
package main

import "fmt"

func deferTest() {
	defer fmt.Println("defer 1")
	defer fmt.Println("defer 2")
	fmt.Println("正常执行")
}

func main() {
	deferTest()
}

执行顺序:

正常执行
defer 2
defer 1

6. 处理文件操作错误

  • 文件操作涉及错误处理,os.OpenFile() 返回 error,要检查是否为 nil
package main

import (
	"fmt"
	"os"
)

func openFile() {
	file, err := os.OpenFile("test.txt", os.O_RDONLY, 0666)
	if err != nil {
		fmt.Println("打开文件失败:", err)
		return
	}
	defer file.Close()
	fmt.Println("文件打开成功")
}

func main() {
	openFile()
}

7. recover 结合 defer 进行异常恢复

  • recover() 只能在 defer 内部使用,否则无法捕获 panic
  • 可以用 recover 拦截异常,防止整个程序崩溃
package main

import "fmt"

func safeRun() {
	defer func() {
		if r := recover(); r != nil {
			fmt.Println("捕获异常:", r)
		}
	}()
	panic("这是一个 panic 例子")
}

func main() {
	safeRun()
	fmt.Println("程序没有崩溃,继续执行")
}

8. 手动 panic

  • panic() 直接终止当前函数,沿调用栈向上传播。
  • 通常用于 不可恢复的严重错误(如数组越界)。
package main

import "fmt"

func checkIndex(index int) {
	if index < 0 {
		panic("索引不能为负数")
	}
	fmt.Println("索引有效:", index)
}

func main() {
	checkIndex(1)
	checkIndex(-1) // 这里会触发 panic
}


http://www.kler.cn/a/594468.html

相关文章:

  • 网络空间安全(36)数据库权限提升获取webshell思路总结
  • 【模拟面试】计算机考研复试集训(第七天)
  • Jvm运行时数据区有哪些
  • ubuntu升级后网卡不可用,提示*-network UNCLAIMED
  • 【redis】在 Spring中操作 Redis
  • docker学习整理
  • 早餐 3.20
  • AI时代,谁能拯救后端开发
  • AI时代API安全挑战加剧,解读API防护的最佳方案
  • sqli-labs学习笔记
  • Redis哨兵模式-黑马学习笔记
  • 如何避免Bug跟踪系统混乱
  • 【分布式锁通关指南 08】源码剖析redisson可重入锁之释放及阻塞与非阻塞获取
  • 【保姆级】阿里云codeup配置Git的CI/CD步骤
  • 【软件工程】综合应用题
  • Apache SeaTunnel脚本升级及参数调优实战
  • 智能护栏报警系统提升高速公路安全
  • 无人机智能控制系统未来技术发展分析
  • Docker DockerFile和Django最佳实践
  • VSTO(C#)Excel开发11:自定义任务窗格与多个工作簿