【go从零单排】结构嵌套struct embedding

🌈Don't worry , just coding!
内耗与overthinking只会削弱你的精力,虚度你的光阴,每天迈出一小步,回头时发现已经走了很远。

📗概念

在Go语言中,结构体嵌套(struct embedding)是一种强大的特性,它允许在一个结构体中嵌入另一个结构体,从而实现组合和复用。嵌套结构体可以让你创建更加复杂的数据结构,同时保持代码的简洁性和可读性。

💻代码

go 复制代码
package main

import "fmt"

// type关键字定义base struct
type base struct {
	num int
}

// 定义函数describe,输入一个base类型,输出一个string
func (b base) describe() string {
	return fmt.Sprintf("base with num=%v", b.num)
}

// container结构嵌套base
type container struct {
	base
	str string
}

func main() {
	//使用字段初始化嵌套结构,指明了base
	//co是container的实例
	co := container{
		base: base{
			num: 1,
		},
		str: "some name",
	}
	//使用co.num 、co.str访问字段
	fmt.Printf("co={num: %v, str: %v}\n", co.num, co.str)
	//用全名访问字段co.base.num
	fmt.Println("also num:", co.base.num)
	//访问describe方法co.describe()
	fmt.Println("describe:", co.describe())
	//定义接口describer,内部调用describe方法
	type describer interface {
		describe() string
	}
	//实现接口,调用co结构,由于base已经被嵌套进来,可以直接实现base中的describe方法
	var d describer = co
	fmt.Println("describer:", d.describe())
}

//输出go run post.go
//co={num: 1, str: some name}
//also num: 1
//describe: base with num=1
//describer: base with num=1

🔍理解

  • 被嵌套的结构体字段直接可以访问,方法可以直接被调用
  • 代码复用:可以将公共字段和方法定义在一个结构体中,然后在其他结构体中嵌套,避免重复代码。
  • 逻辑分组:将相关的字段组合在一起,使得数据结构更加清晰。
  • 简化访问:嵌套结构体的字段可以直接通过外部结构体访问,无需每次都指定嵌套结构体的名称。

💡 Tips小知识点

💪无人扶我青云志,我自踏雪至山巅。

相关推荐
花酒锄作田5 小时前
MCP官方Go SDK尝鲜
golang·mcp
会跑的葫芦怪5 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
xiaoqi9226 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233227 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88218 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1368 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
2601_949833398 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
军军君019 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi92210 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
qq_1777673711 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos