New caching mechanism
This commit is contained in:
33
main_test.go
Normal file
33
main_test.go
Normal file
@ -0,0 +1,33 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"testing"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
var code = "Hello World"
|
||||
var slice = []byte("Hello World 2")
|
||||
|
||||
func BenchmarkStringToBytesSafe(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
slice = []byte(code)
|
||||
}
|
||||
}
|
||||
|
||||
func BenchmarkStringToBytesUnsafe(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
slice = *(*[]byte)(unsafe.Pointer(&code))
|
||||
}
|
||||
}
|
||||
|
||||
func BenchmarkBytesToStringSafe(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
code = string(slice)
|
||||
}
|
||||
}
|
||||
|
||||
func BenchmarkBytesToStringUnsafe(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
code = *(*string)(unsafe.Pointer(&slice))
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user