第十三节:面向对象(扩展已有类型)

当有的功能需要在别人的基础上扩展时该怎么做呢?

比如一个java里面的类,我们可以继承它,然后再写我们自己的逻辑,但是go没有继承,我肯可以使用以下方法:

定义别名

使用组合

接着上次的代码,树的遍历,上次实现了中序遍历,这次实现后序遍历。

上次遍历的代码:

func (node *Node) Traverse()  {
	if node == nil{
		return
	}
	node.LeftNode.Traverse()
	node.Print()
	node.RightNode.Traverse()
}

接下来就实现一下后序遍历:

type myNode struct {
	node *tree.Node
}

func (node *myNode) postOrder()  {
	if node==nil || node.node==nil{
		return
	}
	myNode{node.node.LeftNode}.postOrder()
	myNode{node.node.RightNode}.postOrder()
	node.node.Print()
}

定义了一个新的结构,叫做:myNode   ,然后在myNode 中封装一个tree.Node,然后再给定义一个postOrder的方法,实现后序遍历,挺复杂的,需要理解一下这个关系。

然后是调用:

myNode{&root}.postOrder()

控制台输出:

# tree/entry
.\entry.go:16:28: cannot call pointer method on myNode literal
.\entry.go:16:28: cannot take the address of myNode literal
.\entry.go:17:29: cannot call pointer method on myNode literal
.\entry.go:17:29: cannot take the address of myNode literal
.\entry.go:36:15: cannot call pointer method on myNode literal
.\entry.go:36:15: cannot take the address of myNode literal

Compilation finished with exit code 2

控制台报错了,大概意思就是:无法在myNode上调用指针方法,因为我们是这样写的:

myNode{node.node.LeftNode}.postOrder()

没有定义一个新的变量来接收它,编译器可能就找不到地址,修改一下写法:

func (node *myNode) postOrder()  {
	if node==nil || node.node==nil{
		return
	}
	left:=myNode{node.node.LeftNode}
	left.postOrder()
	right:=myNode{node.node.RightNode}
	right.postOrder()
	node.node.Print()
}


调用:

	m:=myNode{&root}
	m.postOrder()

控制台:

nodeValue: 2
nodeValue: 0
nodeValue: 4
nodeValue: 5
nodeValue: 3

这样就好了。

使用组合:

package quene

type Quene []int

func (q *Quene) Push(v int)  {
	*q = append(*q,v)
}

func (q *Quene) Pop() int  {
	head:=(*q)[0]
	*q=(*q)[1:]
	return head
}

func (q *Quene)IsEmpty() bool  {
	return len(*q)==0
}

通过slice实现一个队列,并且添加Push(),Pop(),IsEmpty(),三个方法。

func main() {
	q:=quene.Quene{1}
	q.Push(2)
	q.Push(3)
	fmt.Println(q.Pop())
	fmt.Println(q.IsEmpty())
	fmt.Println(q.Pop())
	fmt.Println(q.Pop())
	fmt.Println(q.IsEmpty())
}

控制台:

1
false
2
3
true

Process finished with exit code 0

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值