zoukankan      html  css  js  c++  java
  • Go 错误处理

    Go 语言通过内置的错误接口提供了非常简单的错误处理机制。

    error类型是一个接口类型,这是它的定义:

    type error interface {
        Error() string
    }
    

    我们可以在编码中通过实现 error 接口类型来生成错误信息。

    函数通常在最后的返回值中返回错误信息。使用errors.New 可返回一个错误信息:

    func Sqrt(f float64) (float64, error) {
        if f < 0 {         return 0, errors.New("math: square root of negative number")     }     // 实现 } 

    在下面的例子中,我们在调用Sqrt的时候传递的一个负数,然后就得到了non-nil的error对象,将此对象与nil比较,结果为true,所以fmt.Println(fmt包在处理error时会调用Error方法)被调用,以输出错误,请看下面调用的示例代码:

    result, err:= Sqrt(-1)
    
    if err != nil {
       fmt.Println(err)
    }
    

    实例

    package main
    
    import (
        "fmt"
    )
    
    // 定义一个 DivideError 结构
    type DivideError struct {
       dividee int
       divider int
    }
    
    // 实现     `error` 接口
    func (de *DivideError) Error() string {
       strFormat := `
        Cannot proceed, the divider is zero.
      dividee: %d
       divider: 0
    `
     return fmt.Sprintf(strFormat, de.dividee)
    }
    
    // 定义 `int` 类型除法运算的函数
    func Divide(varDividee int, varDivider int) (result int, errorMsg string) {
        if varDivider == 0 {
          dData := DivideError{
             dividee: varDividee,
              divider: varDivider,
          }
         errorMsg = dData.Error()
          return
        } else {
          return varDividee / varDivider, ""
      }
    
    }
    
    func main() {
    
     // 正常情况
       if result, errorMsg := Divide(100, 10); errorMsg == "" {
            fmt.Println("100/10 = ", result)
        }
     // 当被除数为零的时候会返回错误信息
       if _, errorMsg := Divide(100, 0); errorMsg != "" {
          fmt.Println("errorMsg is: ", errorMsg)
      }
    
    }
    

    执行以上程序,输出结果为:

    100/10 =  10
    errorMsg is:  
       Cannot proceed, the divider is zero.
      dividee: 100
      divider: 0
    
    
  • 相关阅读:
    【转】Entity Framework教程
    【转】《我的WCF之旅》博文系列汇总
    【转】无废话WCF系列教程
    【转】 wpf系列-入门
    基于Extjs的web表单设计器 第五节——数据库设计
    基于Extjs的web表单设计器 第四节——控件拖放
    基于Extjs的web表单设计器 第三节——控件拖放
    基于Extjs的web表单设计器 第二节——表单控件设计
    基于Extjs的web表单设计器 第一节
    基于Extjs的web表单设计器
  • 原文地址:https://www.cnblogs.com/navysummer/p/8458589.html
Copyright © 2011-2022 走看看