返回介绍

03.3.7 使用 sort.Slice() 排序

发布于 2024-08-14 12:50:32 字数 3795 浏览 0 评论 0 收藏 0

本节介绍sort.Slice(),这个函数是在Go 1.8中被初次引入的。这意味着sortSlice.go中的代码不能在低于1.8版本的Go环境中运行。这部分代码将分三部分解释,第一部分是:

package main

import (
   "fmt"
   "sort"
)

type aStructure struct {
   person string
   height int
   weight int
}

你可能是第一次在本书中看到Go structure,在第四章组合类型的使用中,你将全面了解Go structure的知识。现在你只需要记住,结构体是拥有不同类型的多个变量的数据类型。

下面是第二部分代码:

sort.Slice(mySlice, func(i, j int) bool {
      return  mySlice[i].height < mySlice[j].height
   })
   fmt.Println("<:", mySlice)

   sort.Slice(mySlice, func(i, j int) bool {
      return mySlice[i].height > mySlice[j].height
   })
   fmt.Println(">:",mySlice)
}

在这里你创建了一个名为mySlice的切片,元素是aStructure结构体。

最后一部分代码:

sort.Slice(mySlice, func(i, j int) bool {
      return  mySlice[i].height < mySlice[j].height
   })
   fmt.Println("<:", mySlice)

   sort.Slice(mySlice, func(i, j int) bool {
      return mySlice[i].height > mySlice[j].height
   })
   fmt.Println(">:",mySlice)
}

我们使用了sort.Slice()及两个匿名函数对mySlice进行排序,匿名函数使用了aStructureheight字段。

sort.Slice() 函数根据匿名排序函数对切片中的元素进行排序。

执行sort.Slice.go之后,将会得到下面的输出:

$ go run sortSlice.go
0: [{Mihalis 180 90} {Bill 134 45} {Merietta 155 45} {Epifanios 144 50} {Athina 134 40}]
<: [{Bill 134 45} {Athina 134 40} {Epifanios 144 50} {Merietta 155 45} {Mihalis 180 90}]
: [{Mihalis 180 90} {Merietta 155 45} {Epifanios144 50} {Bill 134 45} {Athina 134 40}]

如果你在Go版本低于1.8的UNIX系统中执行sort.Slice(),就会得到下面的错误信息:

$ go version
go version g01.3.3 linux/amd64
$ go run sortSlice.go
./sortSlice.go:24: undefined: sort.Slice
./sortSlice.go:24: undefined: sort.Slice

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文