go语言中的map是基于哈希表实现的,遍历的时候是无序的,可以使用delete(map, key)
的方法删除map中的数据。
清空整个map
我们先看一段如下代码:
func tDelMap() {
m := make(map[int]int)
for i := 0; i < 100; i++ {
m[i] = i
}
fmt.Println(len(m)) // 100
for i, v := range m {
delete(m, i)
}
fmt.Println(len(m)) // 0
}
这样是可以删除map中的数据的,并且也不会出现类似遍历删除数组的下标越界的问题。循环遍历了len(m)次。上面的代码每一次遍历都会删除一个元素,而遍历的次数并不会因为之前每次删一个元素导致减少。
但是这样做可能会导致map的内存一直占用不释放,通常我们这样做:
func tDelMap() {
m := make(map[int]int)
for i := 0; i < 100; i++ {
m[i] = i
}
m = nil
}
直接给map赋值为nil,让垃圾回收器去处理它。