package os
func IsExist(err error) bool
func IsNotExist(err error) bool
func IsPermission(err error) bool
func IsNotExist(err error) bool {
//注意:不健壮
return strings.Contains(err.Error(),"file does not exist")
}
一个更可靠的方法是用专门的类型来表示结构化的错误值。OS 包定义了一个 PathError 类型来表示在与一个文件路径相关的 *** 作上发生错误(比如 Open 或者 Delete),一个类似的 linkError 用来表述在与两个文件路径相关的 *** 作上发生错误(比如 Symlink 和 Rename)。下面是 os.pathError 的定义:
package os// PathError 记录了错误以及错误相关的 *** 作和文件路径type PathError struct { Op string Path string Err error}func (e *PathError) Error() string { return e.Op + " " + e.Path + ": " + e.Err.Error()}很多客户端忽略了 PathError,改用一种统一的方法来处理所有的错误,即调用 Error 方法。PathError 的 Error 方法只是拼接了所有的字段,而 PathError 的结构则保留了错误所有的底层信息。对于那些需要区分错误的客户端,可以使用类型断言来检查错误的特定类型,这些类型包含的细节远远多于一个简单的字符串。
_,err := os.Open("/no/such/file")
fmt.Println(err) // "open /no/such/file: No such file or directory"
fmt.Printf("%#v\n",err)
//输出:
// &os.pathError{Op: "open",Path: "/no/such/file",Err:0x2}
import ( "errors" "syscall")var ErrNotExist = errors.New("file does not exist")// IsNotExist返回一个布尔值,该值表明错误是否代表文件或目录不存在// report that a file or directory does not exist. It is satisfIEd by// ErrNotExist 和其他一些系统调用错误会返回 truefunc IsNotExist(err error) bool { if pe,ok := err.(*PathError); ok { err = pe.Err } return err == syscall.ENOENT || err == ErrNotExist}实际使用情况如下:
_,err := os.Open("/no/such/file")
fmt.Println(os.IsNotExist(err)) // "true"
以上是内存溢出为你收集整理的Go语言使用类型断言来识别错误全部内容,希望文章能够帮你解决Go语言使用类型断言来识别错误所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)