go语言中的错误处理与其他语言有些不同,通常使用 error 类型表示函数的结果,如果函数执行失败,则返回一个错误值。在go语言中,没有异常机制,所有的错误都必须返回并进行处理。而在处理错误时,经常需要将错误信息转换成字符串输出或者写日志。
转换 error 类型为字符串有两种方式,分别是使用 error 接口的 Error() 方法和使用 fmt 包的 Sprintf() 函数。
使用 error 接口的 Error() 方法
error 接口是一个规范,包含一个单一的方法 Error() string,实现这个接口的类型表示一个错误状态。我们可以使用这个方法获取错误的字符串表示。
示例代码:
package main
import (
"errors"
"fmt"
)
func main() {
err := errors.New("发生了一个错误")
fmt.Println(err.Error())
}程序输出:
立即学习“go语言免费学习笔记(深入)”;
发生了一个错误
这样就将 error 类型转换成了字符串类型。
使用 fmt.Sprintf() 函数
除了使用 error 接口的 Error() 方法转换错误,我们还可以使用 fmt 包中的 Sprintf() 函数将错误格式化成字符串输出。
示例代码:
package main
import (
"errors"
"fmt"
)
func main() {
err := errors.New("发生了一个错误")
fmt.Println(fmt.Sprintf("%v", err))
}程序输出:
立即学习“go语言免费学习笔记(深入)”;
发生了一个错误
可以看到,使用 fmt.Sprintf() 函数输出错误与使用 error 接口的 Error() 方法输出错误的内容是一样的。
将错误写入日志
除了输出错误信息,我们还可以将错误写入日志文件,这样便于后期排查问题。
示例代码:
package main
import (
"errors"
"log"
)
func main() {
err := errors.New("发生了一个错误")
log.Println("错误信息:", err)
}程序输出:
立即学习“go语言免费学习笔记(深入)”;
2021/08/12 20:06:19 错误信息: 发生了一个错误
可以看到,使用 log 包的 Println() 函数将错误信息写入日志文件。
总结
在Go语言中,将 error 类型转换成字符串有两种方式,分别是使用 error 接口的 Error() 方法和使用 fmt 包的 Sprintf() 函数。同时,我们还可以将错误信息写入日志文件,方便排查问题。










