1. defer执行顺序
package main
import "fmt"
func main(){
defer_call() //后进先出 堆排序
}
func defer_call(){
defer func() {fmt.Println("打一枪就跑")}()
defer func() {fmt.Println("打两枪才跑")}()
defer func() {fmt.Println("挂了。。。")}()
panic("触发异常") //都执行完才会执行这里
}
运行截图:
总结:
defer是后进先出,类似于堆排序,先放的在下面,后放的在上面,而要取出来,则需要先从上面一个一个取出来,就得先将后放的先取出来了。还有就是panic的异常触发是需要defer执行完毕才会执行的。
2. OOP继承
package main
import "fmt"
type People struct {
}
func (p *People)ShowA(){
fmt.Println("SHowAAAA")
p.ShowB()
}
func (p *People)ShowB(){
fmt.Println("ShowBBB")
}
type Teacher struct {
People
}
func (t *Teacher)ShowB(){
fmt.Println("teacher ShowB")
}
func main(){
t := Teacher{}
t.ShowA()
fmt.Println("```````````````````")
t.ShowB()
fmt.Println("`````````````````````")
t.People.ShowB()
fmt.Println("~~~~~~~~~~~~~~~~~~~~~~")
t.People.ShowA()
}
运行截图:
总结:
golang的组合继承问题,实现OOP继承,Poeple结构体有两个方法ShowA和ShowB,新增Teacher结构体且继承了People(类似于python类的继承吧),Teacher有一个方法ShowB,当执行ShowB时因为有新定义的ShowB方法,所以打印只有teacher ShowB,而执行ShowA时,因为没有重新定义Teacher的ShowA,所以会去找Teacher下的People的ShowA,就打印出SHOwAAAA,继续找,找到了People的ShowB方法,打印ShowBBB。
我的掘金:https://juejin.im/post/5dc27457f265da4d307f18ec
有疑问加站长微信联系(非本文作者)