Go语言并发编程:从聊天服务器到共享变量的并发处理
在Go语言的并发编程中,我们会遇到各种有趣且具有挑战性的场景。下面将深入探讨聊天服务器的实现以及共享变量并发处理中常见的问题和解决方案。
1. 取消操作与测试技巧
在并发编程中,取消操作是一个重要的功能。以下是一个用于读取目录项的函数 dirents ,它支持取消操作:
func dirents(dir string) []os.FileInfo {
select {
case sema <- struct{}{}: // acquire token
case <-done:
return nil // cancelled
}
defer func() { <-sema }() // release token
// ...read directory...
}
当取消操作发生时,所有后台的goroutine会迅速停止,主函数返回。在测试时,为了判断主函数是否能正确清理资源,可以采用一个小技巧:在取消操作发生时,不直接从主函数返回,而是调用 panic 。这样运行时会转储程序中每个goroutine的栈信息。如果最后只剩下主goroutine,说明它已经完成了资源清理;如果还有其他goroutine存在,可能是这些goroutine没有被正确取消,或者取消操作需要一些时间,这时就值得进一步调查。
2. 练习题
- 练习8.10
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



