go context记录

文章目录

contex

context.WithCancel使用示例:

package main

import (
	"context"
	"log"
	"time"
)

func main() {
	ctx, cancel := context.WithCancel(context.Background())
	// 启动goroutine处理
	go func(ctx context.Context) {
		i := 0
		for {
			// 检测ctx是否被取消
			select {
			// 调用cancel后直接返回
			case <-ctx.Done():
				log.Println("context done")
				return
			// 没有被取消继续工作睡眠1秒后继续工作
			case <-time.After(time.Second):
				log.Println(i)
				i++
			}
		}
	}(ctx)

	// 主流程
	// ...
	time.Sleep(time.Second * 10)
	cancel()
	time.Sleep(time.Second)
}

context.WithValue使用示例:

package main

import (
	"context"
	"log"
	"time"
)

func main() {
	ctx := context.WithValue(context.Background(), "id", "id_001")
	// 启动goroutine处理
	f := func(ctx context.Context, key string) {
		value := ctx.Value(key)
		if value != nil {
			log.Println("Get value success, key:", key, "id:", value)
		} else {
			log.Println("Get value failed, key:", key)
		}
	}
	f(ctx, "id")
	f(ctx, "name")
	// 主流程
	// ...
	time.Sleep(time.Second)
}

context.WithDeadline使用示例

package main

import (
	"context"
	"log"
	"time"
)

func main() {
	ctx, cancel := context.WithDeadline(context.Background(), time.Now().Add(time.Second*5))

	go func(ctx context.Context) {
		// 定时检测ctx是否Done
		i := 0
		for {
			select {
			case <-ctx.Done():
				log.Println("context done")
				return
			// 每隔一秒检测一次,并执行子任务
			case <-time.After(time.Second):
				log.Println(i)
				i++
				// goroutine 处理子任务
				// ...
			}
		}

	}(ctx)

	// 主流程
	// ...
	time.Sleep(time.Second * 10)
	cancel()
	time.Sleep(time.Second)
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值