如题,我需要在建立 TCP 连接之后循环处理来自客户端的连接请求,并接收来自客户端的数据,在客户端第三次发送数据之后断开连接,取消监听,我使用 select 来取消无缓冲通道的阻塞,但是 handleTcpConnection 向通道发送信号后,sendAndReceiveTcpData 没办法接收信号,导致程序卡死在 handleTcpConnection

如果不用 select 则程序会阻塞在 sendAndReceiveTcpData 接收通道的代码处,没办法处理第二个用户请求,求问怎么解决该问题

func sendAndReceiveTcpData(ln net.Listener) {
defer func() {
	helper.Wt.Done()
	log.Println("sendAndReceiveTcpData 返回")
}()
exitSignal := make(chan bool)
log.Println("信号创建")
var clientNumber = 1
for {
	log.Printf("等待第%d 客户端请求\n", clientNumber)
	conn, err := ln.Accept()
	log.Println("接到请求")
	if err != nil {
		log.Fatalf("和客户端连接失败%s\n", err)
	}
	log.Println("和客户端连接成功")
	clientNumber++
	helper.Wt.Add(1)
	go handleTcpConnection(conn, &exitSignal)

	log.Println("handleTcpConnection 协程创建")
	select {
	case <-exitSignal:
		e := <-exitSignal
		log.Println("接到信号")
		if e{
			goto x
		}
	default:
		log.Println("下一轮")
	}
}
x:
	log.Println("结束 senddata for 循环")
}
func handleTcpConnection(conn net.Conn, e *chan bool) bool {
    defer func() {
        helper.Wt.Done()
        log.Print("handleTcpConnection 返回\n")

    }()

    br := bufio.NewReader(conn)
    var counter = 0
    for {
        data, err := br.ReadString('\n')
        if err == io.EOF {
            break
        }
        if counter == 3{
            log.Println("发送信号")
            *e<-true
            break
        }
        log.Printf("客户端 %s => %s", conn.RemoteAddr(), data)
        counter++
    }
    log.Println("结束 handle for 循环")
    return true
}