代码拉取完成,页面将自动刷新
同步操作将从 kevwan/go-zero 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
package main
import (
"bufio"
"fmt"
"os"
"sync"
"sync/atomic"
"time"
"github.com/tal-tech/go-zero/core/lang"
"github.com/tal-tech/go-zero/core/syncx"
)
func main() {
var count int32
var consumed int32
pool := syncx.NewPool(80, func() interface{} {
fmt.Printf("+ %d\n", atomic.AddInt32(&count, 1))
return 1
}, func(interface{}) {
fmt.Printf("- %d\n", atomic.AddInt32(&count, -1))
}, syncx.WithMaxAge(time.Second))
var waitGroup sync.WaitGroup
quit := make(chan lang.PlaceholderType)
waitGroup.Add(100)
for i := 0; i < 100; i++ {
go func() {
defer func() {
waitGroup.Done()
fmt.Println("routine quit")
}()
for {
select {
case <-quit:
return
default:
x := pool.Get().(int)
atomic.AddInt32(&consumed, 1)
pool.Put(x)
}
}
}()
}
bufio.NewReader(os.Stdin).ReadLine()
close(quit)
fmt.Println("quitted")
waitGroup.Wait()
fmt.Printf("consumed %d\n", atomic.LoadInt32(&consumed))
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。