diff options
| author | apocelipes <seve3r@outlook.com> | 2025-10-20 10:15:42 +0000 |
|---|---|---|
| committer | Gopher Robot <gobot@golang.org> | 2025-10-20 10:19:38 -0700 |
| commit | 3e43f48cb6311c3c459f5c7aa69ae7d28b7fc821 (patch) | |
| tree | 38cdf9607b856ac31b4ea0a20a5035473c9ab494 /src/encoding | |
| parent | 4ad5585c2c2dc3e4387c10c297669c57449156c9 (diff) | |
| download | go-3e43f48cb6311c3c459f5c7aa69ae7d28b7fc821.tar.xz | |
encoding/asn1: use reflect.TypeAssert to improve performance
Use "reflect.TypeAssert" can gain some performance improvements:
goos: darwin
goarch: arm64
pkg: encoding/asn1
cpu: Apple M4
│ old │ new │
│ sec/op │ sec/op vs base │
ObjectIdentifierString-10 51.48n ± 1% 49.72n ± 2% -3.41% (p=0.000 n=10)
Marshal-10 7.549µ ± 0% 7.466µ ± 1% -1.10% (p=0.000 n=10)
Unmarshal-10 1.808µ ± 0% 1.798µ ± 0% -0.58% (p=0.000 n=10)
geomean 889.0n 873.8n -1.70%
│ old │ new │
│ B/op │ B/op vs base │
ObjectIdentifierString-10 32.00 ± 0% 32.00 ± 0% ~ (p=1.000 n=10) ¹
Marshal-10 7.336Ki ± 0% 7.336Ki ± 0% ~ (p=1.000 n=10) ¹
Unmarshal-10 432.0 ± 0% 432.0 ± 0% ~ (p=1.000 n=10) ¹
geomean 470.0 470.0 +0.00%
¹ all samples are equal
│ old │ new │
│ allocs/op │ allocs/op vs base │
ObjectIdentifierString-10 1.000 ± 0% 1.000 ± 0% ~ (p=1.000 n=10) ¹
Marshal-10 271.0 ± 0% 271.0 ± 0% ~ (p=1.000 n=10) ¹
Unmarshal-10 24.00 ± 0% 24.00 ± 0% ~ (p=1.000 n=10) ¹
geomean 18.67 18.67 +0.00%
¹ all samples are equal
Updates #62121
Change-Id: I139b9d0c729c36018d4e00216ab6fc8388f3b51b
GitHub-Last-Rev: c87aae53727dd151fadf60f6d0089d7f6a805005
GitHub-Pull-Request: golang/go#75825
Reviewed-on: https://go-review.googlesource.com/c/go/+/710555
Reviewed-by: Roland Shoemaker <roland@golang.org>
Reviewed-by: Keith Randall <khr@google.com>
Reviewed-by: Keith Randall <khr@golang.org>
Auto-Submit: Keith Randall <khr@golang.org>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Diffstat (limited to 'src/encoding')
| -rw-r--r-- | src/encoding/asn1/marshal.go | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/src/encoding/asn1/marshal.go b/src/encoding/asn1/marshal.go index 70e4fafc12..ddb3bd85dd 100644 --- a/src/encoding/asn1/marshal.go +++ b/src/encoding/asn1/marshal.go @@ -460,17 +460,20 @@ func makeBody(value reflect.Value, params fieldParameters) (e encoder, err error case flagType: return bytesEncoder(nil), nil case timeType: - t := value.Interface().(time.Time) + t, _ := reflect.TypeAssert[time.Time](value) if params.timeType == TagGeneralizedTime || outsideUTCRange(t) { return makeGeneralizedTime(t) } return makeUTCTime(t) case bitStringType: - return bitStringEncoder(value.Interface().(BitString)), nil + v, _ := reflect.TypeAssert[BitString](value) + return bitStringEncoder(v), nil case objectIdentifierType: - return makeObjectIdentifier(value.Interface().(ObjectIdentifier)) + v, _ := reflect.TypeAssert[ObjectIdentifier](value) + return makeObjectIdentifier(v) case bigIntType: - return makeBigInt(value.Interface().(*big.Int)) + v, _ := reflect.TypeAssert[*big.Int](value) + return makeBigInt(v) } switch v := value; v.Kind() { @@ -605,7 +608,7 @@ func makeField(v reflect.Value, params fieldParameters) (e encoder, err error) { } if v.Type() == rawValueType { - rv := v.Interface().(RawValue) + rv, _ := reflect.TypeAssert[RawValue](v) if len(rv.FullBytes) != 0 { return bytesEncoder(rv.FullBytes), nil } @@ -650,7 +653,8 @@ func makeField(v reflect.Value, params fieldParameters) (e encoder, err error) { tag = params.stringType } case TagUTCTime: - if params.timeType == TagGeneralizedTime || outsideUTCRange(v.Interface().(time.Time)) { + t, _ := reflect.TypeAssert[time.Time](v) + if params.timeType == TagGeneralizedTime || outsideUTCRange(t) { tag = TagGeneralizedTime } } |
