Copy Bytes Alternatively (#12608)

* copy bytes alternatively

* test
This commit is contained in:
Nishant Das 2023-07-10 19:47:29 +08:00 committed by GitHub
parent 0a68d2d302
commit d56a530c86
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 35 additions and 0 deletions

View File

@ -71,6 +71,10 @@ func SafeCopyRootAtIndex(input [][]byte, idx uint64) ([]byte, error) {
// SafeCopyBytes will copy and return a non-nil byte slice, otherwise it returns nil. // SafeCopyBytes will copy and return a non-nil byte slice, otherwise it returns nil.
func SafeCopyBytes(cp []byte) []byte { func SafeCopyBytes(cp []byte) []byte {
if cp != nil { if cp != nil {
if len(cp) == 32 {
copied := [32]byte(cp)
return copied[:]
}
copied := make([]byte, len(cp)) copied := make([]byte, len(cp))
copy(copied, cp) copy(copied, cp)
return copied return copied

View File

@ -2,6 +2,7 @@ package bytesutil_test
import ( import (
"bytes" "bytes"
"fmt"
"reflect" "reflect"
"testing" "testing"
@ -248,3 +249,33 @@ func TestFromBytes48Array(t *testing.T) {
assert.DeepEqual(t, tt.a, a) assert.DeepEqual(t, tt.a, a)
} }
} }
func TestSafeCopyBytes_Copy(t *testing.T) {
slice := make([]byte, 32)
slice[0] = 'A'
copiedSlice := bytesutil.SafeCopyBytes(slice)
assert.NotEqual(t, fmt.Sprintf("%p", slice), fmt.Sprintf("%p", copiedSlice))
assert.Equal(t, slice[0], copiedSlice[0])
slice[1] = 'B'
assert.NotEqual(t, slice[1], copiedSlice[1])
}
func BenchmarkSafeCopyBytes(b *testing.B) {
dSlice := make([][]byte, 900000)
for i := 0; i < 900000; i++ {
slice := make([]byte, 32)
slice[0] = 'A'
dSlice[i] = slice
}
b.ReportAllocs()
b.ResetTimer()
b.Run("Copy Bytes", func(b *testing.B) {
cSlice := bytesutil.SafeCopy2dBytes(dSlice)
a := cSlice
_ = a
})
}