blob: 60ee4ecf85edf8a02aace79143cae79fd577a913 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
// run
// Copyright 2022 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package main
import "math"
func checkClearSlice() {
s := []int{1, 2, 3}
clear(s)
for i := range s {
if s[i] != 0 {
panic("clear not zeroing slice elem")
}
}
clear([]int{})
}
func checkClearMap() {
m1 := make(map[int]int)
m1[0] = 0
m1[1] = 1
clear(m1)
if len(m1) != 0 {
panic("m1 is not cleared")
}
// map contains NaN keys is also cleared.
m2 := make(map[float64]int)
m2[math.NaN()] = 1
m2[math.NaN()] = 1
clear(m2)
if len(m2) != 0 {
panic("m2 is not cleared")
}
clear(map[int]int{})
}
func main() {
checkClearSlice()
checkClearMap()
}
|