Go泛型实战 | 如何在结构体中使用泛型
大家好,我是渔夫子。上一篇文章给大家介绍了Go泛型的三步曲。今天给大家分享一篇在结构体中使用泛型的具体示例。
01 目标
假设我们要实现一个blog系统,我们有两个结构体:分类和文章。为了提高系统的性能,我们需要实现一个缓存系统,该缓存可以用于缓存该系统中的分类和文章。
分类和文章的结构体类型定义如下:
type Category struct {
ID int32
Name string
Slug string
}
type Post struct {
ID int32
Categories []Category
Title string
Text string
Slug string
}
02 实现
根据Go泛型使用的三步曲:类型参数化、定义类型约束、类型实例化,我们一步步来定义我们的泛型缓存结构体。
第一步:定义类型约束
这里我们先定义类型约束。因为在泛型中对类型参数进行约束是必要条件。所以要先定义类型约束。
因为要对分类Category类型和文章Post类型进行缓存,所以我们这里的缓存类型约束限制在了这两个类型上。约束接口定义如下:
type cacheable interface {
Category | Post
}
第二步:对类型进行参数化
现在我们创建一个名为cache的泛型结构体,并使用cacheable对其进行约束。
type cache[T cacheable] struct {
data map[string]T
}
我们看到cache的底层实际上是用map来进行存储数据的,map的key是具体的类型字符串,而map的值是参数化的类型T,即要在具体使用时根据需要对该参数T进行实例化。
为了能够在cache结构体中存储和获取数据,我们再定义两个方法如下:
func (c *cache[T]) Set(key string, value T) {
c.data[key] = value
}
func (c *cache[T]) Get(key string) (v T) {
if v, ok := c.data[key]; ok {
return v
}
return
}
这里需要大家注意的是在泛型结构体类型中,定义方法的时候,也需要将类型参数T带上的。因为只有在调用时对类型参数实例化后结构体中的类型才是明确的。
第三步:类型实例化
为了实例化cache结构体,我们创建了一个New函数来专门构造cache的实例。
func New[T cacheable]() *cache[T]{
c := cache[T]{}
c.data = make(map[string]T)
return &c
}
这里大家需要注意的是因为我们使用了泛型结构体类型cache,所以函数New也必须是泛型函数,只有这样才能将泛型类型T的具体值传递到泛型结构体类型中。
当然,这里还有另外一种实例化的cache的方法就是直接使用,这样就不需要使用泛型函数New了。如下:
c := &cache[Category]{
data: make(map[string]T)
}
好了,下面我们给出具体的main函数使用示例:
好了,以上就是今天跟大家分享的内容。
欢迎关注「Go学堂」,让知识活起来
相关文章
- 我偷偷学了这五个命令,打印Linux环境变量那叫一个“丝滑”
- 12 个关于 vim 的编辑技巧
- Linux 中如何获取文件的绝对路径
- 如何检查 Linux 服务器的运行时间
- Linux 中如何使用 id 命令,它是做什么用的呢?
- 什么是 Azure Synapse,它与 Azure Data Bricks 有何不同?
- 定价模型,该如何做分析?
- 浅谈我所见识的数据治理项目
- 跟着小白一起学鸿蒙--]简单Http客户端(十二)
- 三方库移植之NAPI开发--异步调用:Callback&Promise(四)
- 你了解 Linux 文件权限和所有权吗?
- 2022年数据治理和运营安全领域的发展趋势
- 使用 useradd 命令在 Linux 中添加新用户
- Linux 中如何检查开放的端口
- 在Linux中,怎样只显示隐藏文件?
- Github上八个优秀的React项目
- 如何在 bash shell 脚本中 echo 一个新行
- 为什么2022年仍然存在数据孤岛?
- Go 语言怎么优化重复的 if err != nil 样板代码?
- OS内核的信号机制:所有的异步都可以是同步的