title | description |
---|---|
You can't remove a `NaN` key from a golang map without clearing it |
Since `NaN` is not equal to itself, you can't remove it from a map by calling the `delete()` function. |
Consider the following example code:
package main
import (
"fmt"
"math"
)
func main() {
m := map[float64]string{
1: "one",
math.NaN(): "not a number",
}
fmt.Println("Original: ", m)
delete(m, 1)
delete(m, math.NaN())
fmt.Println("After deleting: ", m)
}
It will output:
Original: map[NaN:not a number 1:one]
After deleting: map[NaN:not a number]
As you can see, the NaN
value is not removed from the map.
NaN
values are not equal to themselves, so the delete()
function can't find the key to remove it.
You can completely clear the map by calling the clear()
built-in function that was introduced in go1.21.0, or alternatively you can build a new map by iterating the original one, and skipping the NaN
keys by using the math.IsNaN()
function:
A corollary of NaN
keys not being equal to other NaN
keys is that you can have as many NaN
keys as you want:
package main
import (
"fmt"
"math"
)
func main() {
m := map[float64]string{
math.NaN(): "first",
math.NaN(): "second",
}
fmt.Println("Original: ", m)
m[math.NaN()] = "third"
fmt.Println("Modified: ", m)
}
Prints:
Original: map[NaN:second NaN:first]
Modified: map[NaN:third NaN:second NaN:first]