看代码:
package main
import "fmt"
func main(){
defer func(){
fmt.Println("c")
// if err := recover(); err != nil{
// fmt.Println(err)
// }else{
// fmt.Println("hehe")
// }
// if err := recover(); err != nil{
// fmt.Println(err)
// }else{
// fmt.Println("haha")
// }
fmt.Println("d")
}()
f()
defer func(){
fmt.Println("e")
}()
}
func f(){
fmt.Println("a")
panic(10000)
fmt.Println("b")
fmt.Println("f")
}
结果:
ubuntu@VM-0-15-ubuntu:~/taoge/go$ go run test.go
a
c
d
panic: 10000
goroutine 1 [running]:
panic(0x4b8480, 0xc82000a2c0)
/usr/lib/go-1.6/src/runtime/panic.go:481 +0x3e6
main.f()
/home/ubuntu/taoge/go/test.go:34 +0x115
main.main()
/home/ubuntu/taoge/go/test.go:25 +0x35
exit status 2
ubuntu@VM-0-15-ubuntu:~/taoge/go$
看代码:
package main
import "fmt"
func main(){
defer func(){
fmt.Println("c")
if err := recover(); err != nil{
fmt.Println(err)
}else{
fmt.Println("hehe")
}
if err := recover(); err != nil{
fmt.Println(err)
}else{
fmt.Println("haha")
}
fmt.Println("d")
}()
f()
defer func(){
fmt.Println("e")
}()
}
func f(){
fmt.Println("a")
panic(10000)
fmt.Println("b")
fmt.Println("f")
}
结果:
ubuntu@VM-0-15-ubuntu:~/taoge/go$ go run test.go
a
c
10000
haha
d
ubuntu@VM-0-15-ubuntu:~/taoge/go$
好好体会下。