内容简介:最近接手其他同学代码,发现业务功能实现了,但是对于在代码上,利用虽然看上去,代码没啥大问题,这里有个潜在问题,利用channel的通信来发送数据,导致channel暴露在外部。接下来,我们看下示例2看,经过:point_up_2:上面代码改造,是不是隐藏了channel的细节,不产生channel的交互式调用关系,不要着急,我们看下面示例3:point_down:
最近接手其他同学代码,发现业务功能实现了,但是对于在代码上,利用 channel 来充当回调函数,导致channel在整个代码中传递来,传递去,看起来相当痛苦,代码维护性也比较糟糕。下面写一些列子来说明这个情况。
示例1:利用channel充当callback
package main
import (
"fmt"
"time"
)
func main() {
ch := make(chan int)
go handleMsg(ch)
for index := range ch {
fmt.Println(index)
}
}
func handleMsg(ch chan int) {
t := time.Tick(time.Second)
index := 0
for {
select {
case <-t:
ch <- index
index++
}
}
}
虽然看上去,代码没啥大问题,这里有个潜在问题,利用channel的通信来发送数据,导致channel暴露在外部。接下来,我们看下示例2
示例2:隐藏内部细节,使用只读channel
package main
import (
"fmt"
"time"
)
func main() {
for val := range handleMsg() {
fmt.Println("index", val)
}
}
func handleMsg() <-chan int {
ch := make(chan int)
t := time.Tick(time.Second * 1)
index := 0
go func(index int) {
for {
select {
case <-t:
ch <- index
index++
}
}
}(index)
return ch
}
看,经过:point_up_2:上面代码改造,是不是隐藏了channel的细节,不产生channel的交互式调用关系,不要着急,我们看下面示例3:point_down:
示例3:函数做参数callback
package main
import (
"fmt"
"time"
)
func main() {
callBack := func(index int) {
fmt.Println("index:",index)
}
handleMsg(callBack)
}
func handleMsg(callBack func(index int)) {
t := time.Tick(time.Second)
index := 0
for {
select {
case <-t:
callBack(index)
index++
}
}
}
因为golang的函数可以做参数传递,可以很好解决回调的问题,这样没有带来channel使用的烦恼,似乎,利用callback这个特性,使得在代码上,看起来更加简洁明了。
以上所述就是小编给大家介绍的《golang中channel使用心得》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- COSBench使用心得
- Django使用心得(二) 使用TestCase测试接口
- 携程大佬分享es使用心得
- 关于UniRx的使用心得分享
- Go modules使用心得一
- redis、Memcached、MongoDb使用心得
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
蚁群算法原理及其应用
段海滨 / 科学出版社 / 2005年2月1日 / 48.0
《蚁群算法原理及其应用(精装)》系统、深入地介绍了蚁群算法的原理及其应用,力图概括国内外在这一学术领域的最新研究进展。全书共包括10章,主要内容包括蚁群算法的思想起源、研究现状及机制原理;蚁群算法的复杂度分析;蚁群算法的收敛性证明;蚁群算法参数对其性能的影响;蚁群算法的参数选择原则;离散域和连续域蚁群算法的若干改进策略;蚁群算法在多个优化领域的典型应用;蚁群算法的硬件实现技术;蚁群算法与其他仿生优......一起来看看 《蚁群算法原理及其应用》 这本书的介绍吧!