golang的协程

  1. 启动一个协程
    使用go关键字启动一个新的协程时,就是并发地执行一个函数。换句话说,go关键字后面必须跟着一个可调用的函数(或者是一个匿名函数、闭包等)。
go 复制代码
func sayHello() {   fmt.Println("Hello, World!")  }    
func main() {  go sayHello() // 启动一个新的协程 }
  1. 子协程的生命周期
    • 当主协程结束时,会立即终止所有其他协程。为了确保子协程在主协程退出前完成,可以使用同步机制如 sync.WaitGroup、通道(channel)或 context 包。
    • 使用go起一个协程后,子协程是并发的,并不影响原程序继续执行,并不会阻塞,所以要防止主协程在子协程结束前退出。
  2. select
    • select语句用于处理多个通信操作,它类似于 switch 语句,但它专门用于处理通道(channel)。它会在多个通道操作上等待,直到其中一个通道可以进行发送或接收操作。
    • select 语句会阻塞,直到其中一个 case 可以执行。如果有多个 case 都可以执行,select 会随机选择一个执行。
    • 如果某个通道被关闭,接收操作会立即成功并返回通道类型的零值,而无需阻塞。
go 复制代码
select {  
	case <-chan1:  
	    // 当从chan1成功接收到数据时执行的代码  
	case chan2 <- 1:  
	    // 当成功向chan2发送数据时执行的代码  
	default:  
	    // 如果没有任何通道操作准备就绪时执行的代码  
}
  1. channel
    在Go语言中,channel是一种用于协程(goroutine)之间进行通信和数据同步的机制。它可以被看作是一种特殊的数据类型,类似于队列或管道,用于在不同的协程之间传递数据。
    • 如果向一个未初始化的channel发送数据,发送操作会永远阻塞。
    • 关闭后的channel不能再发送数据,否则会导致运行时错误。
    • 从已关闭的channel接收数据会得到零值:当channel被关闭且没有更多数据时,接收操作会立即返回一个对应类型的零值。
    • 关闭channel不是必须的:只有在通知接收方所有的数据都发送完毕的时候才需要关闭channel。关闭一个已经关闭的channel会导致panic。
  2. context
    我的博客:https://blog.csdn.net/m0_51866860/article/details/142234364
相关推荐
雨中飘荡的记忆17 分钟前
Multi-Agent + Skills + Spring AI 构建自主决策智能体
后端·spring
我叫黑大帅1 小时前
Go 语言并发编程的 “工具箱”
后端·面试·go
用户8356290780511 小时前
Python 实现 PowerPoint 形状动画设置
后端·python
用户908324602732 小时前
Spring Boot 缓存架构:一行配置切换 Caffeine 与 Redis,透明支持多租户隔离
后端
tyung2 小时前
zhenyi-base 开源 | Go 高性能基础库:TCP 77万 QPS,无锁队列 16ns/op
后端·go
子兮曰2 小时前
Humanizer-zh 实战:把 AI 初稿改成“能发布”的技术文章
前端·javascript·后端
桦说编程2 小时前
你的函数什么颜色?—— 深入理解异步编程的本质问题(上)
后端·性能优化·编程语言
百度地图汽车版3 小时前
【AI地图 Tech说】第九期:让智能体拥有记忆——打造千人千面的小度想想
前端·后端
臣妾没空3 小时前
Elpis 全栈框架:从构建到发布的完整实践总结
前端·后端
喷火龙8号3 小时前
单 Token 认证方案的进阶优化:透明刷新机制
后端·架构