```
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秒,已停止
超时之后的内容
```
主程序不停止,协助将会一直执行,要想协助中的某部分代码不执行,只能给协助传递一个信号(通过chanel或者变量等),协助内部做判断。 另外代码中的for{} return 是多余的吧,select case会自动阻塞吧。
#3
更多评论
协程之间同步咯,另外加一个带缓冲的chan,主线程执行完后,往里面塞东西,子协程time.sleep后看该chan是否有值,有就跳过,说明主线程执行完毕
```
func main() {
ch := make(chan string)
bfch := make(chan uint8, 1)
go doit(ch, bfch)
for {
select {
case msg := <-ch:
fmt.Println(msg)
return
case <-time.After(3 * time.Second):
fmt.Println("本次执行超过3秒,已停止")
//需要这里停止之后,不再打印【超时之后的内容】这句话
bfch <- 1
time.Sleep(5 * time.Second)
return
}
}
}
func doit(ch chan string, bfch chan uint8) {
msg := ""
fmt.Println("开始执行")
time.Sleep(5 * time.Second)
if len(bfch) == 0 {
fmt.Println("超时之后的内容")
}
ch <- msg
}
```
#1