教程集 www.jiaochengji.com
教程集 >  Golang编程  >  golang教程  >  正文 Golang map range遍历结果不稳定问题

Golang map range遍历结果不稳定问题

发布时间:2022-01-11   编辑:jiaochengji.com
教程集为您提供Golang map range遍历结果不稳定问题等资源,欢迎您收藏本站,我们将为您提供最新的Golang map range遍历结果不稳定问题资源

闲言少叙,本文主要是想介绍一个Golang开发常见的一个问题。然而,此问题对于初学者来说却经常容易陷入坑中。


问题

我在写一段代码时,使用了Golang的map数据结构,目的是想用map缓存计数结果。简单来说map的键也是整型的,且以递增顺序存储。我的最初想法是,在统计结束后,按照map中存储的键有序输出值。可是,当我运行程序时,结果并不是我想要的,而且有一定概率运行结果不同。

<em>问题代码</em>

<pre>func sortByBits(arr []int) []int { var bitmap = make(map[int][]int, 0) // map缓存 for i := 0; i < len(arr); i { bits := calBits(arr[i]) if _, ok := bitmap[bits]; !ok { tmp := make([]int, 0) tmp = append(tmp, arr[i]) bitmap[bits] = tmp } else { bitmap[bits] = append(bitmap[bits], arr[i]) for j := len(bitmap[bits]) - 1;j > 0; j-- { if bitmap[bits][j] < bitmap[bits][j - 1] { bitmap[bits][j], bitmap[bits][j - 1] = bitmap[bits][j - 1], bitmap[bits][j] } } } } // 输出 var res []int for _, value := range bitmap { res = append(res, value...) } return res } func calBits(n int) int { sum := 0 for n > 0 { if n & 1 == 1 { sum } n = n >> 1 } return sum }</pre>

当发现这个问题后,我使用二维数组替换map,改造代码如下:

<em>改造代码</em>

<pre>func sortByBits(arr []int) []int { var bitmap = make([][]int, 0, 10000) // map缓存 for i := 0; i < len(arr); i { bits := calBits(arr[i]) if len(bitmap) <= bits { length := bits - len(bitmap) 1 for j := 0; j < length; j { tmp := make([]int, 0) bitmap = append(bitmap, tmp) } } if len(bitmap[bits]) == 0 { bitmap[bits] = append(bitmap[bits], arr[i]) } else { bitmap[bits] = append(bitmap[bits], arr[i]) for j := len(bitmap[bits]) - 1;j > 0; j-- { if bitmap[bits][j] < bitmap[bits][j - 1] { bitmap[bits][j], bitmap[bits][j - 1] = bitmap[bits][j - 1], bitmap[bits][j] } } } } // 输出 var res []int for _, value := range bitmap { res = append(res, value...) } return res } func calBits(n int) int { sum := 0 for n > 0 { if n & 1 == 1 { sum } n = n >> 1 } return sum }</pre>

代码很简单,问题也很简单。原理就是Golang的map按键输出结果是随机的,这是语言本身的一个特性,或者说是"坑"。作为开发者,要熟练掌握语言最基本特性,才能开发出最稳健的程序。

到此这篇关于“Golang map range遍历结果不稳定问题”的文章就介绍到这了,更多文章或继续浏览下面的相关文章,希望大家以后多多支持JQ教程网!

您可能感兴趣的文章:
Golang map range遍历结果不稳定问题
golang for range原理(转载)
Go range实现原理及性能优化剖析
Golang从入门到放弃200618--Map(1)Map的初始化和基本操作
golang遍历时修改被遍历对象
golang学习之map排序方法
for-range造就循环永动机?快来看看go中for-range的那些事!
Go语言小知识之map遍历
golang map 排序 key value
golang key map 所有_谨慎使用golang中的map

[关闭]
~ ~