golang的context和chan 的使用

1. context 作用

context包的context的接口,主要是控制协程执行上下文的时间,以及取消程序的执行,以及上下文中传递数据等作用,golang中耗时或者需要协同的操作都会见到context的身影。

context有几个常用的方法

1.1 context.Backgroud()

创建一个空白的,顶级的,不会被取消的上下文。

1.2 context.WithTimeout

创建一个有执行时间限制的上下文

func WithTimeout(parent Context, timeout time.Duration) (Context, CancelFunc) {

return WithDeadline(parent, time.Now().Add(timeout))

}

可以通过ctx.Done()方法获取上下超时的通知。

go 复制代码
package main

import (
	"context"
	"fmt"
	"time"
)

func main() {
	parentCxt := context.Background()
	ctx, cancel := context.WithTimeout(parentCxt, time.Second*5)

	go longTimeTask(ctx)

	time.Sleep(time.Second * 10)
	cancel()
	fmt.Println("task cancel success")
}

func longTimeTask(ctx context.Context) {
	for {
		//fmt.Println("ok")
		select {
		case <-time.After(time.Second * 1):
			fmt.Println("task compete")
		case <-ctx.Done():
			fmt.Println("time out")
			return
		}
	}
}

1.3 context.WitchCancel(parentContext)

获取一个可以中止的上下文,该方法会返回一个新的context,和cancel函数,调用cancel函数后,通过ctx.Done()方法可以获取到上下文取消的通知

go 复制代码
package main

import (
	"context"
	"fmt"
	"time"
)

func main() {
	parentCxt := context.Background()
	ctx, cancel := context.WithCancel(parentCxt)

	go longTimeTask(ctx)

	time.Sleep(time.Second * 10)
	cancel()
	fmt.Println("task cancel success")
}

func longTimeTask(ctx context.Context) {
	for {
		//fmt.Println("ok")
		select {
		case <-time.After(time.Second * 1):
			fmt.Println("task compete")
		case <-ctx.Done():
			fmt.Println("time out")
			return
		}
	}
}

1.4 context.WithValue()

func WithValue(parent Context, key, val any) Context {

if parent == nil {

panic("cannot create context from nil parent")

}

if key == nil {

panic("nil key")

}

if !reflectlite.TypeOf(key).Comparable() {

panic("key is not comparable")

}

return &valueCtx{parent, key, val}

}

可以在上下文中存贮一些参数,通过上下文随时获取。

2.chan 信道

golang的chan和map,切片,接口,函数一样是引用类型。

golang更加推荐使用chan去解决并发的协作的问题,对chan的读写是并发安全的,当然你也可也以使用sync.Mutex等包来控制并发。

相关推荐
雨中飘荡的记忆36 分钟前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
开心就好20252 小时前
UniApp开发应用多平台上架全流程:H5小程序iOS和Android
后端·ios
悟空码字2 小时前
告别“屎山代码”:AI 代码整洁器让老项目重获新生
后端·aigc·ai编程
小码哥_常2 小时前
大厂不宠@Transactional,背后藏着啥秘密?
后端
奋斗小强2 小时前
内存危机突围战:从原理辨析到线上实战,彻底搞懂 OOM 与内存泄漏
后端
小码哥_常3 小时前
Spring Boot接口防抖秘籍:告别“手抖”,守护数据一致性
后端
心之语歌3 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
None3213 小时前
【NestJs】基于Redlock装饰器分布式锁设计与实现
后端·node.js
初次攀爬者3 小时前
Kafka + KRaft模式架构基础介绍
后端·kafka
洛森唛3 小时前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch