速战速决 go - go 容器: 列表(列表的增删改查和遍历)

速战速决 go https://github.com/webabcd/GoSample
作者 webabcd

速战速决 go - go 容器: 列表(列表的增删改查和遍历)

示例如下:

container/list.go

// go 容器 - 列表(列表的增删改查和遍历)
// 注:
// 1、List 中可以包含不同类型的数据
// 2、添加进 List 中的数据都会被封装为 Element 对象
// 3、通过 Element.Value 获取或修改元素的值

package container

import (
	"container/list"
	"fmt"
)

func ListSample() {
	list_sample1()
	list_sample2()
}

func list_sample1() {
	// 声明一个 List(此处的 a 是一个指针)
	a := list.New()
	// 声明一个 List(此处的 b 是指针指向的值)
	var b list.List
	fmt.Printf("%p, %p\n", a, &b) // 0xc000110480, 0xc0001104b0

	// 在尾部添加一个数据
	// a 是指针,这里不是应该写成 (*a).PushBack("a") 吗?当然可以这么写,不过由于 go 支持语法糖(syntactic sugar)技术,他会自动转换的,所以你也可以按如下方式写
	a.PushBack("a") // a
	// 在开头添加一个数据
	a.PushFront(0) // 0 a
	// 在尾部添加一个 List
	a.PushBackList(a) // 0 a 0 a

	b.PushBack(true)
	// 在开头添加一个 List
	a.PushFrontList(&b) // true 0 a 0 a

	// 返回值就是你添加数据对应的 Element 对象
	el := a.PushBack("x") // true 0 a 0 a x
	// 在指定的 Element 对象之后添加数据
	a.InsertAfter("x_after", el) // true 0 a 0 a x x_after
	// 在指定的 Element 对象之前添加数据
	a.InsertBefore("x_before", el) // true 0 a 0 a x_before x x_after

	// 删除指定的 Element 对象
	a.Remove(el) // true 0 a 0 a x_before x_after

	// 遍历 List
	for i := a.Front(); i != nil; i = i.Next() {
		fmt.Println(i.Value)
	}
}

func list_sample2() {
	a := list.New()
	a.PushBack(0)
	a.PushBack(1)
	a.PushBack(2)
	a.PushBack(3)
	a.PushBack(4)
	a.PushBack(5)

	// List 有如下方法
	//   Font() - 取第一个数据的 Element 对象
	//   Back() - 取最后一个数据的 Element 对象
	//   MoveToFront(), MoveToBack(), MoveBefore(), MoveAfter() - 移动 Element 对象的相关操作
	// Element 有如下方法和属性
	//   Next() - 获取当前 Element 对象的在 List 中的下一个 Element 对象(没有则会返回 nil)
	//   Prev() - 获取当前 Element 对象的在 List 中的上一个 Element 对象(没有则会返回 nil)
	//   Value - 表示 Element 对象的值
	b := a.Front().Next()        // 1
	c := a.Front().Next().Next() // 2
	// 将 c 移动到 List 的开头
	a.MoveToFront(c) // 2 0 1 3 4 5
	// 将 b 移动到 c 的后面
	a.MoveAfter(b, c) // 2 1 0 3 4 5

	// 修改指定 Element 对象的值
	a.Back().Value = 100 // // 2 1 0 3 4 5

	// 取指定 Element 对象的值
	fmt.Println(b.Value, c.Value) // 1 2

	// 遍历 List
	for i := a.Front(); i != nil; i = i.Next() {
		fmt.Println(i.Value)
	}
}

速战速决 go https://github.com/webabcd/GoSample
作者 webabcd

posted @ 2022-02-08 14:22  webabcd  阅读(157)  评论(0编辑  收藏  举报