02 2022 档案

摘要:需求 对变量并发执行10000次相加 示例1:裸奔 package main import ( "fmt" "sync" ) var xx int var wg111 sync.WaitGroup func add() { xx++ wg111.Done() } func main() { wg11 阅读全文
posted @ 2022-02-13 23:02 jihite 阅读(119) 评论(2) 推荐(0) 编辑
摘要:需求 高并发场景下,操作只执行一次,如读取配置、单例模式 实现 Go 的sync模块提供了只执行一次的解决方案:sync.Once, 它只有一个函数:Do func (o *Once) Do(f func()) {} 示例1:读取一次配置文件 package main import ( "fmt" 阅读全文
posted @ 2022-02-12 13:46 jihite 阅读(73) 评论(0) 推荐(0) 编辑
摘要:需求 读写共享map #1 常规map package main import ( "fmt" "strconv" "sync" ) func _110Test1() { wg := sync.WaitGroup{} mp := make(map[string]int) for i := 0; i 阅读全文
posted @ 2022-02-09 09:52 jihite 阅读(50) 评论(0) 推荐(0) 编辑
摘要:不加锁 package main import ( "fmt" "sync" ) var x=0 var wg107 sync.WaitGroup func add1() { for i := 0; i < 50000; i++ { x += 1 } wg107.Done() } func test 阅读全文
posted @ 2022-02-09 09:23 jihite 阅读(88) 评论(0) 推荐(0) 编辑
摘要:示例 package main import "fmt" func main() { ch := make(chan int, 1) for i := 0; i < 10; i++ { select { case x := <-ch: fmt.Println(x) case ch <- i: } } 阅读全文
posted @ 2022-02-06 22:39 jihite 阅读(73) 评论(0) 推荐(0) 编辑
摘要:背景 在实际工作中,我们总会限制goroutine数量——worker pool模式,控制goroutine数量,避免goroutine泄露与膨胀 示例 package main import ( "fmt" "time" ) func worker(w int, jobs <-chan int, 阅读全文
posted @ 2022-02-06 18:33 jihite 阅读(163) 评论(0) 推荐(0) 编辑
摘要:理念 GO语言并发模型CSP: 提倡通过通信共享内存,而非通过共享内存实现通信。 如果说goroutine是Go程序并发的执行体,channel就是它们之间的连接。channel是可以让一个goroutine发送特定值到另一个goroutine的通信机制 示例 关闭后任然可以读取 func main 阅读全文
posted @ 2022-02-06 11:09 jihite 阅读(177) 评论(0) 推荐(0) 编辑
摘要:需求 执行完所有子函数后退出主程序 #1. 串行执行 import ( "fmt" "time" ) func f1Sleep(val int) { time.Sleep(time.Duration(val)) fmt.Println(val) } func try0() { fmt.Println 阅读全文
posted @ 2022-02-04 18:12 jihite 阅读(79) 评论(0) 推荐(0) 编辑

点击右上角即可分享
微信分享提示