并发 – 不同的方式传递渠道​​作为参数在功能go(golang)

前端之家收集整理的这篇文章主要介绍了并发 – 不同的方式传递渠道​​作为参数在功能go(golang)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在阅读一些去代码,并说出几种不同的方法来传递渠道。也许他们是一样的,但我想知道是否有任何差异,因为我找不到文件在线:

1)

@H_301_3@func serve(ch <-chan interface{}){ //do stuff }

2)

@H_301_3@func serve(ch chan<- interface{}){ //do stuff }

3)

@H_301_3@func serve(ch chan interface{}){ //do stuff }

4)

@H_301_3@func server(ch *chan interface{}){ //do stuff}

我想知道他们之间的区别是什么,如果他们只是等同的方式来做同样的事情:通过围绕不同的goroutines的频道。

注意:我知道没有理由将指针传递给chan,map或slice或函数值,因为这些都是内部包含指针的引用类型(如果您希望被调用者可以更改该异常)引用类型头)。我提供的唯一原因是完整性(即真正提供一个渠道可以尝试作为一个参数传递,并提出一个问题,希望可以参考所有方法来做这些,并比较它们)。

这些是不同类型的频道。见 http://golang.org/ref/spec#Channel_types。对于指针的东西:不常见,但如果要从函数内部更改通道(从未在野外看到),可能会很有用。

猜你在找的Go相关文章