3.10 Go之channel超时机制
什么是超时?
所谓的超时可以理解为token
过期,需要重新操作
Go
中的channel
超时机制
为了防止channel
被其他goroutine
竞争,所以需要设置一个超时处理器
处理办法:
使用select
来处理超时
Go
中select
的使用方法以及和switch
的区别
select
的特点:
-
其中有一个
case
完成程序就会往下执行而不考虑其他case
的情况 -
每个
case
的语句里面必须是一个i/o
操作 -
select
块当中有多条语句可以执行(多个goroutine
都不阻塞)时随机选择一条来执行
select{
case <-chan1:
// chan1成功读取到数据则执行该case
case chan2 <- 1:
// 成功向chan2写入数据则执行该case
default:
// 如果上面都没有成功,则进入default处理流程
}
所有goroutine
都阻塞的情况:
-
没有定义
default
则select
语句会被阻塞.直到至少有一个通信可以进行下去 -
定义了
default
语句,执行default
.同时程序的执行会从select
语句后的语句中恢复
实例代码:
package main
import (
"fmt"
"time"
)
/*
模拟一个go的超时处理办法
使用select进行处理
*/
func main() {
// 定义两个通道,一个进,一个出
ch := make(chan int)
quit := make(chan bool)
// 开启一个协程进行超时处理
go func() {
// 循环执行select
for {
select {
/* 能从ch通道当中读取到数据 */
case num := <-ch:
fmt.Println("号码 = ", num)
case <-time.After(3 * time.Second):
fmt.Println("超时")
// 同时将该条信息告知出通道--->放入成功
quit <- true
//default:
// fmt.Println("未知情况!")
// quit <- false
}
}
}()
// 循环往ch通道放值
for i := 0; i < 5; i++ {
ch <- i
time.Sleep(time.Second)
}
// 匿名接收quit通道内的值--->只是为了保证goroutine不死锁
judge := <-quit
switch judge {
case true:
fmt.Println("程序结束!")
case false:
fmt.Println("程序异常!")
}
}
分析:
-
前四次执行的是
case num
的操作,最后一次执行的是case <-time.After
的逻辑 -
每次往
ch
通道中放入值的时候都进行了时间等待,为了超时的时候执行time.After
-
**
default
It's a lonely road!!!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话