aboutsummaryrefslogtreecommitdiff
path: root/src/encoding/gob/encode.go
diff options
context:
space:
mode:
authorkorzhao <korzhao@tencent.com>2021-08-04 02:47:57 +0000
committerBryan C. Mills <bcmills@google.com>2021-09-07 19:14:23 +0000
commit903958d2f506decf92a1bfd63dfbecadf8375735 (patch)
tree6e9b4edf0eafe2180f887776e9227dec56353ebd /src/encoding/gob/encode.go
parent66401719143692f1b892fb47aaef286f885395c9 (diff)
downloadgo-903958d2f506decf92a1bfd63dfbecadf8375735.tar.xz
encoding/gob: marshal maps using reflect.Value.MapRange
golang.org/cl/33572 added a map iterator. use the reflect.Value.MapRange to fix map keys that contain a NaN Fixes #24075 Change-Id: I0214d6f26c2041797703e48eac16404f189d6982 GitHub-Last-Rev: 5c01e117f4451dbaec657d02d006905df1d0055d GitHub-Pull-Request: golang/go#47476 Reviewed-on: https://go-review.googlesource.com/c/go/+/338609 Trust: Bryan C. Mills <bcmills@google.com> Run-TryBot: Bryan C. Mills <bcmills@google.com> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Rob Pike <r@golang.org>
Diffstat (limited to 'src/encoding/gob/encode.go')
-rw-r--r--src/encoding/gob/encode.go10
1 files changed, 5 insertions, 5 deletions
diff --git a/src/encoding/gob/encode.go b/src/encoding/gob/encode.go
index 8f8f170c16..f1f5f3862d 100644
--- a/src/encoding/gob/encode.go
+++ b/src/encoding/gob/encode.go
@@ -368,11 +368,11 @@ func (enc *Encoder) encodeMap(b *encBuffer, mv reflect.Value, keyOp, elemOp encO
state := enc.newEncoderState(b)
state.fieldnum = -1
state.sendZero = true
- keys := mv.MapKeys()
- state.encodeUint(uint64(len(keys)))
- for _, key := range keys {
- encodeReflectValue(state, key, keyOp, keyIndir)
- encodeReflectValue(state, mv.MapIndex(key), elemOp, elemIndir)
+ state.encodeUint(uint64(mv.Len()))
+ mi := mv.MapRange()
+ for mi.Next() {
+ encodeReflectValue(state, mi.Key(), keyOp, keyIndir)
+ encodeReflectValue(state, mi.Value(), elemOp, elemIndir)
}
enc.freeEncoderState(state)
}