errors.New用于创建简单错误实例,适用于无额外上下文的场景。示例中divide函数用errors.New(“division by zero”)处理除零错误,main函数捕获并打印错误。相比fmt.Errorf,errors.New不支持格式化字符串,适合固定错误信息,如参数校验、状态检查等简单场景。

在 Go 语言中,errors.New 是创建自定义错误最简单的方式之一。它用于生成一个实现了 error 接口的基础错误实例,适用于不需要额外上下文信息的场景。
errors.New 基本用法
errors.New 接收一个字符串参数,返回一个 error 类型的实例。这个实例在调用 Error() 方法时会返回传入的字符串。
示例:
package mainimport ( "errors" "fmt")func divide(a, b int) (int, error) { if b == 0 { return 0, errors.New("division by zero") } return a / b, nil}func main() { result, err := divide(10, 0) if err != nil { fmt.Println("Error:", err) } fmt.Println("Result:", result)}
输出:
Error: division by zero
Result: 0
自定义错误的适用场景
当错误信息简单、固定,且不需要携带额外字段(如错误码、时间戳等)时,使用 errors.New 是最直接的选择。
函数参数校验失败 状态不符合预期(如资源未初始化) 简单的业务逻辑错误提示
与 fmt.Errorf 的对比
errors.New 不支持格式化输出,如果需要拼接变量,应使用 fmt.Errorf。
立即学习“go语言免费学习笔记(深入)”;
例如:
if b == 0 { return 0, fmt.Errorf("cannot divide %d by zero", a)}
fmt.Errorf 内部也是基于 errors.New 构建,但提供了字符串格式化能力,更加灵活。
基本上就这些。对于简单错误,errors.New 足够清晰高效。需要结构化信息时,可定义自定义错误类型。
以上就是Golangerrors.New创建自定义错误实例方法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1402855.html
微信扫一扫
支付宝扫一扫