ไปจัดการข้อผิดพลาด
ไปภาษาให้เป็นกลไกจัดการข้อผิดพลาดง่ายมากผ่านในตัวอินเตอร์เฟซที่ผิดพลาด
ประเภทข้อผิดพลาดเป็นประเภทอินเตอร์เฟซซึ่งเป็นความหมายของมัน
type error interface { Error() string }
เราสามารถใช้ประเภทอินเตอร์เฟสข้อผิดพลาดในการสร้างข้อผิดพลาดในรหัส
ฟังก์ชั่นทั่วไปส่งกลับข้อผิดพลาดในตอนท้ายของค่าตอบแทนที่ ใช้ errors.New ส่งกลับข้อความข้อผิดพลาด:
func Sqrt(f float64) (float64, error) { if f < 0 { return 0, errors.New("math: square root of negative number") } // 实现 }
ในตัวอย่างต่อไปนี้เราเรียก Sqrt เมื่อผ่านเป็นจำนวนลบแล้วคุณจะได้รับวัตถุข้อผิดพลาดไม่เป็นศูนย์เมื่อเทียบกับศูนย์วัตถุนี้ผลที่ได้คือความจริงดังนั้น fmt.Println (แพคเกจ FMT เมื่อจัดการข้อผิดพลาด ข้อผิดพลาดจะถูกเรียกว่าวิธีการ) เรียกว่าข้อผิดพลาดของการส่งออกให้ดูตัวอย่างรหัสต่อไปเรียก:
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