11.1 错误处理.pdfVIP

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
11.1 错误处理

11.1 错误处理 Go语⾔主要的设计准则是:简洁、明⽩,简洁是指语法和C类似,相当的简单,明⽩ 是指任何语句都是很明显的, 含有任何隐含的东西,在错误处理⽅案的设计中也贯 彻了这⼀思想。我们知道在C语⾔⾥⾯是通过返回-1或者NULL之类的信息来表⽰错 误,但是对于使⽤者来说, 查看相应的API说明⽂档,根本搞 清楚这个返回值究 竟代表什么意思,⽐如:返回0是成功,还是失败,⽽Go定义了⼀个叫做error 的类型,来 显式表达错误。在使⽤时,通过把返回的error变量与nil的⽐较,来判定操作是否成 功。例如os.Open函数在打开⽂件失败时将返回⼀个 为nil的error变量 func Open(name string) (file *File, err error) 下⾯这个例⼦通过调⽤os.Open打开⼀个⽂件,如果出现错误,那么就会调 ⽤log.Fatal来输出错误信息: f, err := os.Open(filename.ext) if err != nil { log.Fatal(err) } 类似于os.Open函数,标准包中所有可能出错的API都会返回⼀个error变量,以⽅便 错误处理,这个⼩节将详细地介绍error类型的设计,和讨论开发Web应⽤中如何更好 地处理error 。 Error类型 error类型是⼀个接⼜类型,这是它的定义: type error interface { rror() string } error是⼀个内置的接⼜类型,我们可以在/builtin/包下⾯找到相应的定义。⽽我们在很 多内部包⾥⾯⽤到的 error是errors包下⾯的实现的私有结构errorString // errorString is a trivial implementation of error. type errorString struct { s string } func (e *errorString) rror() string { return e.s } 你可以通过errors.New把⼀个字符串转化为errorString ,以得到⼀个满⾜接⼜error 的 对象,其内部实现如下: // New returns an error that formats as the given text. func New(text string) error { return errorString{text} } 下⾯这个例⼦演⽰了如何使⽤errors.New: func Sqrt(f float64) (float64, error) { if f 0 { return 0, errors.New(math: square root of negative number } // implementation } 在下⾯的例⼦中,我们在调⽤Sqrt的时候传递的⼀个负数,然后就得到了non-nil的 error对象,将此对象与nil⽐较,结果为true ,所以fmt Println(fmt包在处理error 时会调 ⽤Error⽅法)被调⽤,以输出错误,请看下⾯调⽤的⽰例代码: f, err := Sqrt(-1) if err != nil { fmt.Println(err) } ⾃定义Error 通过上⾯的介绍我们知道error是⼀个interface ,所以在实现⾃⼰的包的时候,通过定 义实现此接⼜的结构,我们就可以实现⾃⼰的错误定义,请看来⾃Json包的⽰例: type Syntax rror struct { msg string // 错误描述 Offset int64 // 错误发⽣的位置 } func (e *Syntax rror) rror() string { return e.msg } Offset字段在调⽤Error 的时候 会被打印,但是我们可以通过类型断⾔获取错误类 型,然后可以打印相应的错误信息,请看下⾯的例⼦: if err := dec.Decode(val); err != nil { if serr, ok := err.(*json.Syntax rror); ok { line, col := findLine(f, serr.Offset) return fmt. rrorf

文档评论(0)

rovend + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档