Golang try catch与错误处理的实现
对于一个Golang开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《Golang try catch与错误处理的实现》,主要介绍了错误处理、try、catch,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!
Golang try catch
虽然在使用Golang的时候发现没有try catch这种错误处理机制但是想一想golang作为一门优雅的语言,似乎也是情理之中。因为在java中 throws在函数签名中有一个关键字,旨在使异常流程比较简洁,但是一旦预期的异常数量增加,就很难准确捕捉到具体异常所在。
虽然golang中并不提供try catch的写法但是零值概念啊等等一些设计,在加上在panic的时候还可以使用recover进行处理,我觉得还是可以接受的。
在进入正题之前我们还是需要新了解一下panic和recover和error
panic
golang新手特别喜欢将panic当作exception(我也是这么过来的。。),而这么做会导致panic被滥用。
panic主要使用场景:
- 发生严重错误必须让进行退出,严重的判断标准是错误无法恢复导致程序无法执行或继续执行或者继续执行也得不到预定的结果,另一些场景就是程序启动需要的初始化数据需要在数据库中读取,这个时候数据库无法读取或者不存在配置项不可读取,这个时候哪怕是执行下去程序也是毫无意义的,这个时候panic暴露出问题反而是更可取的方式。非严重的错误比如客户端不合法的请求参数返回错误参数信息提示即可,让调用者自己去处理问题,而不是自己panic挂掉。
- 快速退出错误处理。也就是下面需要模拟的try catch的行为。大多数情况下错误处理都应该使用判断error的机制,但是有时函数调用栈很深,逐层返回错误可能需要写很多冗余代码,这个时候可以使用panic让程序的控制流直接跳到顶层的recover来进行处理。这种场景需要注意必须在包内就要recover。让panic垮包传递可能会导致更复杂的问题,所以包的到处函数不应该产生panic。
recover
func recover() interface{}
recover 是一个内建的函数,用于重新获得 panic 协程的控制。 只有在延迟函数的内部,调用 recover 才有用。在延迟函数内调用 recover,可以取到 panic 的错误信息,并且停止 panic 续发事件(Panicking Sequence),程序运行恢复正常。如果在延迟函数的外部调用 recover,就不能停止 panic 续发事件。
error
golang中内置的错误类型error是一个接口,自定义的错误类型必须实现error接口,这样调用可以通过Error()获取到具体的错误信息而不用关系错误的具体类型。
// The error built-in interface type is the conventional interface for // representing an error condition, with the nil value representing no error. type error interface { Error() string }
很多语言限制函数只能有一个返回值,这就显得尤为宝贵,而golang的多返回值语法糖避免了这种方式带来的不便,错误值一般作为返回值列表的最后一个,其他返回值是成功执行时需要返回的信息。也就衍生出了如下判断:
if err != nil { // error handling } else { // normal code }
虽然这种错误处理方式代码写起来很蛋疼,但是golang风格确实推荐使用此种方式。
预定义错误值
var numIsZero = errors.New("num1 is zero") var numIsNotZero = errors.New("num1 is not zero") func GetInt(num1 int) (int, error) { if num1 == 0 { return num1, numIsZero } else { return num1, numIsNotZero } } //比较错误 func ErrEquals() { _, err := GetInt(1) if err == numIsNotZero { } }
自定义错误类型
HTTP 表示客户端的错误状态码有几十个。如果为每种状态码都预定义相应的错误值,代码会变得很繁琐:
var ErrBadRequest = errors.New("status code 400: bad request") var ErrUnauthorized = errors.New("status code 401: unauthorized")
这种场景下最佳的最法是自定义一种错误类型,并且至少实现 Error() 方法(满足 error 定义):
type HTTPError struct { Code int Description string } func (h *HTTPError) Error() string { return fmt.Sprintf("status code %d: %s", h.Code, h.Description) }
这种方式下进行等值判断时需要转成具体的自定义类型然后取出 Code 字段判断:
func request() error { return &HTTPError{404, "not found"} } func main() { err := request() if err != nil { // an error occured if err.(*HTTPError).Code == 404 { // handle a "not found" error } else { // handle a different error } } }
使用 panic和recover模拟 tyr catch 谨慎!
tyr catch 需要谨慎使用,因为panic / recover 和 try / catch 机制最大的不同在于控制流程上的区别。try / catch 机制控制流作用在 try 代码块内,代码块执行到异常抛出点(throw)时,控制流跳出 try 代码块,转到对应的 catch 代码块,然后继续往下执行。panic / recover 机制控制流则作用在整个 goroutine 的调用栈。当 goroutine 执行到 panic 时,控制流开始在当前 goroutine 的调用栈内向上回溯(unwind)并执行每个函数的 defer 。如果 defer 中遇到 recover 则回溯停止,如果执行到 goroutine 最顶层的 defer 还没有 recover ,运行时就输出调用栈信息然后退出。所以如果要使用 recover 避免 panic 导致进程挂掉,recover 必须要放到 defer 里。为了避免过于复杂的代码,最好不要使用嵌套的 defer ,并且 recover 应该直接放到 defer 函数里直接调用。
package main import ( "fmt" ) func main() { defer func() { if err := recover(); err != nil { fmt.Println("error:", err) } }() fmt.Println("start") panic("Big Error") fmt.Println("stop") }
输出:
start
error: Big Error
此部分的代码相当于try部分的代码一旦被panic 后面的代码就不会被执行了,而是跳到 defer部分
fmt.Println("start") panic("Big Error") fmt.Println("stop")
接收到错误并处理相当于catch:
defer func() { if err := recover(); err != nil { fmt.Println("error:", err) } }()
注意如果想再次catch需要按照从下往上的循序进行异常处理,原因的话了解defer。:
func main() { defer func() { if err := recover(); err != nil { fmt.Println("error:", err) } }() defer func() { if err := recover(); err != nil { fmt.Println("再次panic") panic(err) } }() fmt.Println("start") panic("Big Error") fmt.Println("stop") } func main() { defer func() { if err := recover(); err != nil { fmt.Println("error:", err) } }() defer func() { if err := recover(); err != nil { fmt.Println("再次panic") panic(err) } }() defer func() { if err := recover(); err != nil { fmt.Println("再次panic") panic(err) } }() defer func() { if err := recover(); err != nil { fmt.Println("再次panic") panic(err) } }() fmt.Println("start") panic("Big Error") fmt.Println("stop") }
输出:
start
再次panic
再次panic
再次panic
error: Big Error
终于介绍完啦!小伙伴们,这篇关于《Golang try catch与错误处理的实现》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

- 上一篇
- golang 实用库gotable的具体使用

- 下一篇
- 试了下Golang实现try catch的方法
-
- 帅气的小土豆
- 这篇文章太及时了,太全面了,很好,已加入收藏夹了,关注大佬了!希望大佬能多写Golang相关的文章。
- 2023-03-08 13:28:58
-
- 愉快的发带
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢大佬分享技术贴!
- 2023-02-25 13:16:48
-
- Golang · Go教程 | 21小时前 |
- Go语言新手必看!切片vs数组,一次搞定这两个核心知识点
- 472浏览 收藏
-
- Golang · Go教程 | 21小时前 |
- Docker在Debian上运行超简单教程(保姆级教学)
- 210浏览 收藏
-
- Golang · Go教程 | 23小时前 |
- Debian设置hostname踩坑记录:权限问题大揭秘
- 334浏览 收藏
-
- Golang · Go教程 | 23小时前 |
- Debian装SQLServer?这些问题你一定要注意!
- 284浏览 收藏
-
- Golang · Go教程 | 1天前 |
- Debian系统下Jenkins自动化部署脚本教学
- 367浏览 收藏
-
- Golang · Go教程 | 1天前 |
- DebianSwap服务器应用实测,这些场景真的用得上!
- 319浏览 收藏
-
- Golang · Go教程 | 1天前 |
- Debian跑TigerVNC实测!真香警告,快来看看性能咋样~
- 171浏览 收藏
-
- Golang · Go教程 | 1天前 |
- 在Debian上玩转SQLServer备份还原,手把手教你一步步操作
- 498浏览 收藏
-
- Golang · Go教程 | 1天前 |
- DebianOverlay不会玩?手把手教你轻松定制化安装
- 258浏览 收藏
-
- Golang · Go教程 | 1天前 |
- Go语言实战:time.Ticker&time.After用法区别及避坑技巧
- 240浏览 收藏
-
- Golang · Go教程 | 1天前 |
- Debian系统如何快速定位&干掉那些讨厌的僵尸进程
- 317浏览 收藏
-
- Golang · Go教程 | 1天前 |
- DebianVNC加密连接设置,超简单教程来了!
- 383浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 5次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 45次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 51次使用
-
- 稿定PPT
- 告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
- 46次使用
-
- Suno苏诺中文版
- 探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
- 50次使用
-
- Go代码规范错误处理示例经验总结
- 2022-12-23 278浏览
-
- 分析Go错误处理优化go recover机制缺陷
- 2023-01-01 483浏览
-
- Go 错误处理实践总结示例
- 2023-01-07 291浏览
-
- Go程序员踩过的defer坑错误处理
- 2023-01-19 195浏览
-
- golang gorm错误处理事务以及日志用法示例
- 2023-02-16 412浏览