登录
首页 >  Golang >  Go问答

如何在 Go 中实现对象比较功能?

来源:stackoverflow

时间:2024-03-20 10:57:29 404浏览 收藏

在 Go 中,对象比较功能通常通过实现自定义类型上的比较方法来实现。例如,对于 `special` 类型,可以定义一个 `Equal` 方法,它接受另一个 `special` 实例作为参数,并比较它们的各个字段。如果需要根据特定标准对对象进行排序,则可以实现 `sort.Interface` 接口或使用 `sort.Slice` 方法,该方法接受自定义比较函数作为参数。通过这种方法,Go 允许开发者根据需要灵活地定义对象比较行为,而无需遵循特定的接口约定。

问题内容

我在研究这个主题时发现了这个问题 - golang 中调用的类似接口是什么?,但它并没有完全回答我的问题。

假设我有一个简单类型特殊

type special struct {
    value int
    isactive bool
    guid string
}

现在我想将我的自定义类型与第三方“二叉树”数据结构一起使用。我想二叉树的实现中将包含一个接口,我需要实现该接口才能将其与我的自定义类型一起使用:

type comparable interface{
    compareto(other comparable) int
}

这很好,但是当我需要使用其他数据结构(例如“排序链接列表”)时会发生什么?我下载了一个不同的包,它有不同的接口来实现:

type Comparable2 interface{
    Compare(other Comparable) int
}

换句话说,每次我需要使用应该知道如何比较我的类型的数据结构时,我都需要向我的类型添加不同的接收器函数(方法)?我认为这有点奇怪。 我是否遗漏了某些内容,或者在使用 go 进行软件开发时如何处理这些情况?


解决方案


事实并非如此。您可以根据需要对自定义类型进行比较。一种常见模式(例如在 time 包中找到的模式)是您的类型上的 equal() 方法,该方法采用相同类型的另一个实例作为参数进行比较。

因此,对于您的示例类型:

type special struct {
    value int
    isactive bool
    guid string
}

这看起来像这样:

func (s Special) Equal(u Special) bool {
    return s.Value == u.Value &&
        s.IsActive == u.IsActive &&
        s.Guid == u.Guid
}

尽管请记住,在这个特定的示例中,这种类型的两个结构无论如何都是可以直接比较的,因为所有底层类型都是可以直接比较的。更多详情请参阅 this answer

如果人们认为直接比较每个字段可以增加清晰度,或者结构将来可能会包含不可比较的字段,那么仍然可以选择使用每个字段的直接比较(正如我所演示的)。

如果您有兴趣为了排序而进行比较,那么这是完全不同的事情(在我看来,假装不是这样的语言从根本上被破坏了)。

如果您的类型可以一致排序,您可以实现 sort.Interface 接口。如果您有一个可以通过不同方式排序的类型,您可能希望改用 sort.Slice 方法,该方法接受任意比较函数作为参数。

以上就是《如何在 Go 中实现对象比较功能?》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>