go 中的 Context 用法

context 可以用来告诉子 grountine 什么时候结束。

复制func worker(ctx context.Context) {
	defer wg.Done()
LABEL:

	for {
		fmt.Println("worker......")
		time.Sleep(time.Second)
		select {
		case <-ctx.Done(): //对于没有缓冲区的 chan,如果后面没有人接,那么就要直接跳过。
			break LABEL
		default:
		}
	}
}

var wg sync.WaitGroup

func main() {
	ctx, cancel := context.WithCancel(context.Background())
	wg.Add(1)
	go worker(ctx)
	time.Sleep(time.Second * 5)
	cancel()  //关闭
	wg.Wait() // 等待
	fmt.Println("over")
}

context控制子程序和子子程序

var wg sync.WaitGroup

func work1(ctx context.Context) {
	defer wg.Done()
	go work2(ctx)
LABEL: //只能写在for循环的上面,直接可以调到这里,且下面的for循环不会再执行
	for {
		select {
		case <-ctx.Done():
			break LABEL
		default:
			time.Sleep(time.Millisecond * 500)
			fmt.Println("work01在工作******")
		}
	}
}

func work2(ctx context.Context) { //串联着把子程序和子子程序都能停下来
	defer wg.Done()
LABEL: 
	for {
		select {
		case <-ctx.Done():
			break LABEL
		default:
			time.Sleep(time.Millisecond * 500)
			fmt.Println("work02在工作******")
		}
	}
}

func main() {
	ctx, cancel := context.WithCancel(context.Background())
	wg.Add(1)
	go work1(ctx)
	time.Sleep(time.Second * 5)
	cancel()
	wg.Wait()
}
posted @   沧海一声笑rush  阅读(222)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示