如果我从来没有检查它的状态,它是否可以让一个Go通道永远打开(从不关闭通道)?它会导致内存泄漏吗?下面的代码可以吗?

func (requestCh chan<- Request) GetResponse(data RequestData) Response {
    reply := make(chan Response)
    requestCh <- Request{data: data, replyCh: reply}
    return <-reply
}

当前回答

“使用Go通道的一个一般原则是,不要从接收端关闭通道,如果通道有多个并发发送方,也不要关闭通道。”

正如上面的回答中明确提到的,每个通道最终都会被GCed,一旦它被标记为清理,所以它可以让通道未关闭,唯一的区别是,该通道将在几个周期后可用,可能没有显式关闭。

下面的文章this和this还展示了在1:N、N:1或M:N(发送方:接收方)的情况下关闭信道的各种方法。

其他回答

如果你手动关闭通道,你就节省了一些垃圾收集器的任务,从而节省了一些计算,并加快了你的程序。

“使用Go通道的一个一般原则是,不要从接收端关闭通道,如果通道有多个并发发送方,也不要关闭通道。”

正如上面的回答中明确提到的,每个通道最终都会被GCed,一旦它被标记为清理,所以它可以让通道未关闭,唯一的区别是,该通道将在几个周期后可用,可能没有显式关闭。

下面的文章this和this还展示了在1:N、N:1或M:N(发送方:接收方)的情况下关闭信道的各种方法。

让Go频道永远打开而不关闭是可以的。当通道不再使用时,它将被垃圾收集。

请注意,只有在接收方处于关闭状态时才有必要关闭通道 寻找一个结束。关闭通道是一个控制信号上 通道,表示后面没有更多数据。 设计问题:通道关闭

是的,保持频道开放是可以的,事实上这是典型的。打开的通道不构成对通道对象的引用,因此不会阻止它被垃圾收集。

上面已经很好地说明了这一点,但是我发现A Tour of Go中的以下内容非常清楚,它也给出了一个何时关闭的例子:

另一个注意事项:通道不像文件;你通常不需要关闭它们。只有在必须告诉接收方没有更多的值时才需要关闭,例如终止一个范围循环。