考虑以下父级和子级结构:
type Parent struct { id string children []Child } type Child struct { id string }
假设我们有一个具有预定义值的 Parent 结构体切片:
parents := []Parent{ { "3", []Child{ {"2"}, {"3"}, {"1"}, }, }, { "1", []Child{ {"8"}, {"9"}, {"7"}, }, }, { "2", []Child{ {"5"}, {"6"}, {"4"}, }, }, }
排序要求:
我们的目标是根据两个标准对parents切片进行排序:
解决方案:
为了实现这种排序,我们利用 sort.Slice 函数,它提供了一种基于自定义比较函数对切片进行排序的灵活方法。代码如下:
<code class="go">// Sort parents by their ID sort.Slice(parents, func(i, j int) bool { return parents[i].id < parents[j].id }) // Iterate over each parent and sort their children by ID for _, parent := range parents { sort.Slice(parent.children, func(i, j int) bool { return parent.children[i].id < parent.children[j].id }) }</code>
此排序算法有效地处理这两个条件,确保父切片按需要排序。
预期结果:
排序后的切片应类似于以下结构:
[{1 [{7} {8} {9}]} {2 [{4} {5} {6}]} {3 [{1} {2} {3}]}]
以上是如何在 Go 中按多个字段对结构体切片进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!