多返回值function
package main
import (
"fmt"
)
func main() {
a, b, c := A()
fmt.Println(a, b, c)
}
func A() (int, int, int) {
a, b, c := 1, 2, 3
return a, b, c
}
不定参
package main
import (
"fmt"
)
func main() {
a, b, c := A(1, 2, 3)
fmt.Println(a, b, c)
}
func A(a ...int) (int, int, int) {
fmt.Println("参数:", a)
b, c, d := 4, 5, 6
return b, c, d
}
函数作为类型
package main
import (
"fmt"
)
func main() {
a := A
a()
}
func A() {
fmt.Println("fuction A")
}
闭包
package main
import (
"fmt"
)
func main() {
a := A(10)
fmt.Println(a(1))
fmt.Println(a(2))
}
func A(x int) func(int) int {
fmt.Printf("%p\n", &x)
return func(y int) int {
fmt.Printf("%p\n", &x)
return x + y
}
}
defer
defer的使用,类似于析构函数,函数执行后按照调用顺序,后进先出
一般用于资源清理,文件关闭,解锁,以及记录时间
通过匿名函数配合可在return后修改函数的计算结构
如果函数体内某个变量作为defer匿名函数参数,则在定义时候已经获得数据的拷贝,否者则是这个变量的地址
package main
import (
"fmt"
)
func main() {
for i := 0; i < 3; i++ {
defer fmt.Println(i)
}
}
package main
import (
"fmt"
)
func main() {
for i := 0; i < 3; i++ {
defer func() {
fmt.Println(i)
}()
}
fmt.Println("hello world")
}
panic/recover
panic可以在任何地方引发,但recover只要在defer才可以有效
package main
import (
"fmt"
)
func main() {
A()
B()
C()
}
func A() {
fmt.Println("func A")
}
func B() {
defer func() {
if err := recover(); err != nil {
fmt.Println(err)
fmt.Println("recover in B")
}
}()
panic("panic in B")
}
func C() {
fmt.Println("func C")
}
defer使用的多个场景
https://chai2010.cn/post/golang/defer-2013/