Commit beadf433 authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

os/exec: provide map size hint in dedupEnvCase

The common case is that most env vars are distinct;
optimize for that.

name        old time/op    new time/op    delta
ExecEcho-8    2.16ms ± 3%    2.14ms ± 1%     ~     (p=0.315 n=10+10)

name        old alloc/op   new alloc/op   delta
ExecEcho-8    7.87kB ± 0%    6.35kB ± 0%  -19.31%  (p=0.000 n=9+10)

name        old allocs/op  new allocs/op  delta
ExecEcho-8      72.0 ± 0%      69.0 ± 0%   -4.17%  (p=0.000 n=10+10)

Change-Id: I42bb696c6862f2ea12c5cbd2f24c64336a7a759a
Reviewed-on: https://go-review.googlesource.com/c/164960
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent 37b84e27
...@@ -713,7 +713,7 @@ func dedupEnv(env []string) []string { ...@@ -713,7 +713,7 @@ func dedupEnv(env []string) []string {
// If caseInsensitive is true, the case of keys is ignored. // If caseInsensitive is true, the case of keys is ignored.
func dedupEnvCase(caseInsensitive bool, env []string) []string { func dedupEnvCase(caseInsensitive bool, env []string) []string {
out := make([]string, 0, len(env)) out := make([]string, 0, len(env))
saw := map[string]int{} // key => index into out saw := make(map[string]int, len(env)) // key => index into out
for _, kv := range env { for _, kv := range env {
eq := strings.Index(kv, "=") eq := strings.Index(kv, "=")
if eq < 0 { if eq < 0 {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment