首页 > 代码库 > golang 函数-defer-recover-panic
golang 函数-defer-recover-panic
函数
1、函数的定义
package main import "fmt" func add(a int, b int) int { // 当函数参数类型相同时,除最后一个外其他类型可省略。 // add(a int,b int) == add(a,b int) return a+b } func main(){ fmt.Println(add(1,2)) } //执行结果: # go run func.go 3
2、函数的多返回值
package main import "fmt" func add(a, b int) (int,int) { return a+b,a-b } func main(){ fmt.Println(add(1,2)) } //执行结果:3 -1
3、函数的匿名返回值
package main import "fmt" func add(a, b int) (x,y int) { x = a + b y = a - b return //返回值定义返回x,y 因此return 后面可省略 } func main(){ fmt.Println(add(1,2)) }
4、函数不定长参数
package main import "fmt" func add(a, b int) (x,y int) { x = a + b y = a - b return } func sum(args ...int) int{ final := 0 for _,value := range args { //当遍历时索引信息不需要可以用"_"来代替. final += value } return final } func main(){ fmt.Println(add(1,2)) fmt.Println(sum(1,2,3,4,5,6)) } //执行结果: 3 -1 21
5、函数嵌套函数
package main import "fmt" func add(a, b int) int { num := 1 sub := func() int{ num -= 1 return num } fmt.Println(sub()) return a+b } func main(){ fmt.Println(add(1,2)) } //执行结果: 0 3
defer
1、defer可以在函数执行体都执行完后在执行
package main import "fmt" func clean(){ fmt.Println(" do something in clean ") } func main(){ defer clean() fmt.Println("end main") } //执行结果: end main do something in clean
recover
1、当程序出错时,可以通过recover来捕捉
package main import "fmt" func safeDivision(a,b int) int { defer func(){ fmt.Println(recover()) }() v := a / b return v } func main(){ safeDivision(1,0) fmt.Println("end main") } //执行结果: runtime error: integer divide by zero end main
panic
1、可以通过panic来抛出异常,通过recover来捕捉
package main import "fmt" func demPanic() { defer func(){ fmt.Println(recover()) }() panic("PANIC") } func main(){ demPanic() fmt.Println("end main") } //执行结果: PANIC end main
本文出自 “欺壹世De博客” 博客,请务必保留此出处http://qiyishi.blog.51cto.com/5731577/1902420
golang 函数-defer-recover-panic
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。