mirror of
https://github.com/Crocmagnon/fat-contexts-article-companion.git
synced 2024-11-14 04:23:53 +01:00
50 lines
1 KiB
Go
50 lines
1 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/gofrs/uuid"
|
|
)
|
|
|
|
const key = "key"
|
|
|
|
func main() {
|
|
const times = 10_000
|
|
|
|
// Setup the value we want to retrieve in each iteration
|
|
ctx := context.WithValue(context.Background(), key, "some-val")
|
|
|
|
fat(ctx, times)
|
|
shadow(ctx, times)
|
|
}
|
|
|
|
func fat(ctx context.Context, times uint64) {
|
|
for range times {
|
|
// wrap the context, each iteration makes it bigger
|
|
ctx = contextWithRandom(ctx)
|
|
|
|
start := time.Now()
|
|
// simulate the logging lib which retrieves context values
|
|
_ = ctx.Value(key)
|
|
|
|
fmt.Printf("fat,%v\n", time.Since(start).Nanoseconds())
|
|
}
|
|
}
|
|
|
|
func shadow(ctx context.Context, times uint64) {
|
|
for range times {
|
|
// shadow the context, each iteration creates a new one and it doesn't grow
|
|
ctx := contextWithRandom(ctx)
|
|
|
|
start := time.Now()
|
|
_ = ctx.Value(key)
|
|
|
|
fmt.Printf("shadow,%v\n", time.Since(start).Nanoseconds())
|
|
}
|
|
}
|
|
|
|
func contextWithRandom(ctx context.Context) context.Context {
|
|
return context.WithValue(ctx, "other_key", uuid.Must(uuid.NewV4()))
|
|
}
|