Context多路复用和任务取消

当我们任务用到子任务时候,如果主任务关闭旗下所有子任务同时关闭那么就要用到Context多路复用 。
一。普通任务的取消
package cancel_by

import (
"fmt"
"testing"
"time"
)

func isCancelled(cancelChan chan struct{}) bool {
//多路选择,当case处于阻塞情况执行default
select {
case <-cancelChan: //是否正常收到消息
return true //通道正常
default:
return false //通道阻塞
}
}

//新增
func cancel_1(cancelChan chan struct{}) {
cancelChan <- struct{}{}
}

//任务取消
func cancel_2(cancelChan chan struct{}) {
close(cancelChan)
}
func TestCancel(t *testing.T) {
cancelChan := make(chan struct{}, 0)
for i := 0; i < 5; i++ {
go func(i int, cancelChan chan struct{}) {
for {
if isCancelled(cancelChan) {
break
}
time.Sleep(time.Millisecond * 5)
}
fmt.Println(i, "Cancelled")
}(i, cancelChan)

}
cancel_2(cancelChan)
time.Sleep(time.Second * 1)
}

二。Context多路复用任务取消(根节点任务取消时候同时取消旗下子任务)
1.根Context:通过context.Background()创建
2.子Context:context.WithCancel(parentContext)创建
3. ctx,cancel:=context.WithCancel(context.Background())
4.当前Context被取消时,基于他的子context都会取消
5.接收取消通知<-ctx.Done()


package cancel_by

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

func isCancelledt(ctx context.Context) bool {
//多路选择,当case处于阻塞情况执行default
select {
case <-ctx.Done(): //是否正常收到消息
return true //通道正常
default:
return false //通道阻塞
}
}

//关联任务
func TestCancelt(t *testing.T) {
ctx, cancelt := context.WithCancel(context.Background()) //父节点
for i := 0; i < 5; i++ {
go func(i int, ctx context.Context) {
for {
if isCancelledt(ctx) {
break
}
time.Sleep(time.Millisecond * 5)
}
fmt.Println(i, "Fk")
}(i, ctx)//ctx子任务

}
cancelt() //取消当前执行cancel的包裹所有子任务
time.Sleep(time.Second * 1)
}

 

 

转载于:https://www.cnblogs.com/quang3727/p/11164381.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值