当前位置: 首页>>编程示例 >>用法及示例精选 >>正文


GO SliceStable用法及代码示例

GO语言"sort"包中"SliceStable"函数的用法及代码示例。

用法:

func SliceStable(x any, less func(i, j int) bool)

SliceStable 使用提供的 less 函数对切片 x 进行排序,保持相等元素的原始顺序。如果 x 不是切片,它会Panics。

less 函数必须满足与接口类型的 Less 方法相同的要求。

例子:

package main

import (
    "fmt"
    "sort"
)

func main() {

    people := []struct {
        Name string
        Age  int
    }{
        {"Alice", 25},
        {"Elizabeth", 75},
        {"Alice", 75},
        {"Bob", 75},
        {"Alice", 75},
        {"Bob", 25},
        {"Colin", 25},
        {"Elizabeth", 25},
    }

    // Sort by name, preserving original order
    sort.SliceStable(people, func(i, j int) bool { return people[i].Name < people[j].Name })
    fmt.Println("By name:", people)

    // Sort by age preserving name order
    sort.SliceStable(people, func(i, j int) bool { return people[i].Age < people[j].Age })
    fmt.Println("By age,name:", people)

}

输出:

By name: [{Alice 25} {Alice 75} {Alice 75} {Bob 75} {Bob 25} {Colin 25} {Elizabeth 75} {Elizabeth 25}]
By age,name: [{Alice 25} {Bob 25} {Colin 25} {Elizabeth 25} {Alice 75} {Alice 75} {Bob 75} {Elizabeth 75}]

相关用法


注:本文由纯净天空筛选整理自golang.google.cn大神的英文原创作品 SliceStable。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。