为了账号安全,请及时绑定邮箱和手机立即绑定

如何在 Go 中对一段版本字符串进行排序

如何在 Go 中对一段版本字符串进行排序

Go
梦里花落0921 2023-02-28 15:43:57
我有一个充满类型版本的数组String,需要排序,但当前的排序方法排序不正确apiVersions := []string{"1.4", "1.12", "1.21", "1.8"}在排序时apiVersions,数组看起来像["1.12", "1.21", "1.4", "1.8"]而不是["1.4", "1.8", "1.12", "1.21"]
查看完整描述

1 回答

?
肥皂起泡泡

TA贡献1829条经验 获得超6个赞

您可能应该使用标准的 Go 语义版本比较包之一来执行此操作,而不是重新发明轮子。对于初学者,使用hashicorp/go-version包来语义比较两个版本字符串


package main


import (

    "fmt"

    "sort"


    "github.com/hashicorp/go-version"

)


type byVersion []string


func (s byVersion) Len() int {

    return len(s)

}


func (s byVersion) Swap(i, j int) {

    s[i], s[j] = s[j], s[i]

}


func (s byVersion) Less(i, j int) bool {

    v1, err := version.NewVersion(s[i])

    if err != nil {

        panic(err)

    }

    v2, err := version.NewVersion(s[j])

    if err != nil {

        panic(err)

    }

    return v1.LessThan(v2)

}


func main() {

    versions := []string{"1.4", "1.12", "1.21", "1.8"}

    sort.Sort(byVersion(versions))

    fmt.Println(versions)

}

产生预期的预期结果。


[1.4 1.8 1.12 1.21]


查看完整回答
反对 回复 2023-02-28
  • 1 回答
  • 0 关注
  • 107 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信