You could run pprof to get a full breakdown. But just looking at your code, it occurs to me that you have goroutines that do pretty much no actual computation. It is basically testing the concurrent performance of *append()*. Without looking at pprof, I can not say for sure where the bottleneck is, but I suspect it would be in the memory allocation. If you modify the program slightly (see https://play.golang.org/p/5rUktxMGAf) to use the same memory for the *[]string* after the first run (line 64), and actually do some computation instead (lines 66-68), then you get the kind of threading performance you would expect:
2017/10/27 13:57:05 Starting 1 threads 2017/10/27 13:57:15 Id routine: 0 rate: 192.307692 2017/10/27 13:57:15 Current total rate was 192.31 K/s 2017/10/27 13:57:46 Starting 2 threads 2017/10/27 13:57:56 Id routine: 0 rate: 196.078431 2017/10/27 13:57:56 Id routine: 1 rate: 196.078431 2017/10/27 13:57:56 Current total rate was 392.16 K/s 2017/10/27 13:58:32 Starting 3 threads 2017/10/27 13:58:42 Id routine: 1 rate: 192.307692 2017/10/27 13:58:42 Id routine: 2 rate: 192.307692 2017/10/27 13:58:42 Id routine: 0 rate: 196.078431 2017/10/27 13:58:42 Current total rate was 580.69 K/s 2017/10/27 13:56:53 Id routine: 1 rate: 192.307692 2017/10/27 13:56:53 Id routine: 3 rate: 192.307692 2017/10/27 13:56:53 Id routine: 0 rate: 192.307692 2017/10/27 13:56:53 Id routine: 2 rate: 188.679245 2017/10/27 13:56:53 Current total rate was 765.60 K/s Hope this helps a bit. Jake On Friday, October 27, 2017 at 8:38:00 AM UTC-4, Christian LeMoussel wrote: > > Hi, I am studying about golang and use of goroutine. > With this sample code, on my PC with 4 logical CPUs, I can't understand > why I don't have any performance improvement. > > If I add in concurrency, the time it takes to do tends to slow down by the > original without concurrency. > > 2017/10/27 13:57:17 Starting 1 threads > 2017/10/27 13:57:27 Id routine: 0 rate: 232.558140 > 2017/10/27 13:57:27 Current total rate was 232.56 K/s > 2017/10/27 13:57:27 Starting 1 threads > 2017/10/27 13:57:37 Id routine: 0 rate: 357.142857 > 2017/10/27 13:57:37 Current total rate was 357.14 K/s > > 2017/10/27 13:58:04 Starting 2 threads > 2017/10/27 13:58:14 Id routine: 0 rate: 131.578947 > 2017/10/27 13:58:14 Id routine: 1 rate: 129.870130 > 2017/10/27 13:58:14 Current total rate was 261.45 K/s > 2017/10/27 13:58:14 Starting 2 threads > 2017/10/27 13:58:24 Id routine: 1 rate: 144.927536 > 2017/10/27 13:58:24 Id routine: 0 rate: 151.515152 > 2017/10/27 13:58:24 Current total rate was 296.44 K/s > > 2017/10/27 13:59:15 Starting 3 threads > 2017/10/27 13:59:25 Id routine: 2 rate: 94.339623 > 2017/10/27 13:59:25 Id routine: 0 rate: 92.592593 > 2017/10/27 13:59:25 Id routine: 1 rate: 90.090090 > 2017/10/27 13:59:25 Current total rate was 277.02 K/s > 2017/10/27 13:59:25 Starting 3 threads > 2017/10/27 13:59:35 Id routine: 2 rate: 92.592593 > 2017/10/27 13:59:35 Id routine: 0 rate: 90.090090 > 2017/10/27 13:59:35 Id routine: 1 rate: 101.010101 > 2017/10/27 13:59:35 Current total rate was 283.69 K/s > > 2017/10/27 14:00:12 Starting 4 threads > 2017/10/27 14:00:22 Id routine: 1 rate: 56.818182 > 2017/10/27 14:00:22 Id routine: 3 rate: 56.818182 > 2017/10/27 14:00:22 Id routine: 0 rate: 61.349693 > 2017/10/27 14:00:22 Id routine: 2 rate: 62.500000 > 2017/10/27 14:00:22 Current total rate was 237.49 K/s > 2017/10/27 14:00:22 Starting 4 threads > 2017/10/27 14:00:32 Id routine: 1 rate: 67.114094 > 2017/10/27 14:00:32 Id routine: 3 rate: 61.349693 > 2017/10/27 14:00:32 Id routine: 0 rate: 57.803468 > 2017/10/27 14:00:32 Id routine: 2 rate: 65.789474 > 2017/10/27 14:00:32 Current total rate was 252.06 K/s > > And, here is the concurrent code with the goroutines: > > package main > > import ( > "fmt" > "log" > "sync" > "time" > ) > > var ( > tryArr []string > goroutineQuit = make(chan struct{}) > concurrencyMapHQ = struct { > sync.RWMutex > HQ map[int]float64 > }{HQ: make(map[int]float64)} > ) > > func rateStats() { > var totalRate float64 > for i, rate := range concurrencyMapHQ.HQ { > log.Printf("Id routine: %d rate: %f", i, rate) > totalRate += rate > } > > log.Printf("Current total rate was %.2f K/s", totalRate) > } > > func stopThreads(threads int) { > for i := 0; i < threads; i++ { > goroutineQuit <- struct{}{} > } > > rateStats() > } > > func runThreads(threads int, steps int) { > log.Printf("Starting %d threads", threads) > > for i := 0; i < threads; i++ { > i := i > go func(id int, steps int) { > calculate(i, steps) > }(i, steps) > } > } > > func calculate(idRoutine int, steps int) { > var ( > possibles []string > numBatchs = 0 > t1 = time.Now() > ) > > for { > select { > case <-goroutineQuit: > return > default: > possibles = nil > > for _, nonce := range tryArr { > possibles = append(possibles, nonce) > } > > numBatchs++ > if numBatchs == 99 { > t2 := time.Now() > > timeExecution := t2.Sub(t1) / time.Millisecond > > concurrencyMapHQ.Lock() > concurrencyMapHQ.HQ[idRoutine] = float64(steps) / > float64(timeExecution) > concurrencyMapHQ.Unlock() > > numBatchs = 0 > t1 = t2 > > } > } > } > } > > func main() { > threads := 4 > steps := 10000 > > tryArr = make([]string, steps) > for i := 0; i < steps; i++ { > tryArr[i] = fmt.Sprintf("indice: %d", i) > } > > for { > runThreads(threads, steps) > time.Sleep(10 * time.Second) > stopThreads(threads) > > runThreads(threads, steps) > time.Sleep(10 * time.Second) > stopThreads(threads) > } > } > > > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.