在像 bytes_read, err := conn.Read(tmp) 这样的语句中,我希望尝试读取 x 秒,如果没有开始读取,我希望代码继续进行检查一些连接并再次循环并尝试读取。我可以使用 select-case 并生成两个 goroutine,一个尝试读取,另一个用于超时。但是在这里,如果首先发生超时,代码将继续执行,检查条件并再次生成一个例程以尝试在先前的读取例程仍处于事件状态时从连接中读取。我希望之前的例程在超时发生时终止。

关于我如何继续的任何建议?

最佳答案

希望这可以帮助你。 ^_^

for {
    // set SetReadDeadline
    err := conn.SetReadDeadline(time.Now().Add(5 * time.Second))
    if err != nil {
        log.Println("SetReadDeadline failed:", err)
        // do something else, for example create new conn
        return
    }

    recvBuf := make([]byte, 1024)

    n, err = conn.Read(recvBuf[:]) // recv data
    if err != nil {
        if netErr, ok := err.(net.Error); ok && netErr.Timeout() {
            log.Println("read timeout:", err)
            // time out
        } else {
            log.Println("read error:", err)
            // some error else, do something else, for example create new conn
        }
    }
}

关于go - 从 golang 中的 tcp 连接读取,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34892507/

10-11 22:45