package main
import (
"fmt"
"time"
)
func main() {
ch := make(chan string)
go doit(ch)
for {
select {
case msg := <-ch:
fmt.Println(msg)
return
case <-time.After(3 * time.Second):
fmt.Println("本次执行超过3秒,已停止")
//需要这里停止之后,不再打印【超时之后的内容】这句话
time.Sleep(5 * time.Second)
return
}
}
}
func doit(ch chan string) {
msg := ""
fmt.Println("开始执行")
time.Sleep(5 * time.Second)
fmt.Println("超时之后的内容")
ch <- msg
}
我期望得到的是
开始执行 本次执行超过3秒,已停止
现在得到的是
开始执行 本次执行超过3秒,已停止 超时之后的内容