Go学习:扩展已有类型

java如果要实现扩展已有类型的话,可以进行继承,但是继承真正做起来会很不灵活,go语言中就直接取消掉了继承;go语言对扩展已有类型提供了定义别名使用组合

使用组合

在这里插入图片描述
代码中的Traverse函数是对Node进行遍历;但是遍历方式是左->中->右;如果我们需要左->右->中就需要自己进行扩展

package main

import (
	"awesomeProject/tree"
	"fmt"
)

type myNode struct {
	node *tree.Node
}

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

func main() {

	var root tree.Node

	root = tree.Node{Value: 3}
	root.Left = &tree.Node{}
	root.Right = &tree.Node{Value: 5}
	root.Right.Left = new(tree.Node)
	root.Left.Right = tree.CreateNode(2)
	root.Right.Left.SetValue(4)

	// 0 2 3 4 5
	root.Traverse()
	fmt.Println()

	// 2 0 4 5 3
	myRoot := myNode{node: &root}
	myRoot.postOrder()
}

定义别名

package queue

type Queue []int

func (queue *Queue) Push(val int) {
	*queue = append(*queue, val)
}

func (queue *Queue) Pop() int {
	popVal := (*queue)[0]
	*queue = (*queue)[1:]
	return popVal
}

func (queue *Queue) IsEmpty() bool {
	return len(*queue) == 0
}

package main

import (
	"awesomeProject/queue"
	"fmt"
)

func main() {

	q := queue.Queue{1}
	q.Push(2)
	q.Push(3)
	fmt.Println(q)	// [1 2 3]
	fmt.Println(q.Pop())	// 1
	fmt.Println(q.Pop())	// 2
	fmt.Println(q.IsEmpty())	// false
	fmt.Println(q)	// [3]
	fmt.Println(q.Pop())	// 3
	fmt.Println(q.IsEmpty())	// true
	fmt.Println(q)	// []
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

.番茄炒蛋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值