goroutine:内存泄露

1、goroutine代表肯或不肯相互平行运转的工作单位。goroutine 有以下几种方式被终止:

    A、当它完成了他的工作

    B、因为不可回复的错误,它不能继续工作

    C、当它被告知需要终止工作

2、main goroutine 具有完整的语境知识应该能够告诉其子goroutine终止。

3、goroutine 很常见的会在一个长寿的程序的初始化的时候就被启动。

    在最糟糕的情况下,main goroutine可能会在其生命周期内持续的将其他的goroutine设置为自旋,这会导致内存利用率的下降。

    将父子goroutine进行成功整合的一种方法就是在父子goroutine之间建立一个“信号通道”,让父goroutine可以向子goroutine发出取消信号。按照惯例,这个信号通常是一个名为done的只读channel。父goroutine将该channel传递给子goroutine,然后想要取消子goroutine时关闭该channel

func main() {
	doWork := func(
		done <-chan interface{},
		strings <-chan string) <-chan interface{} {
		terminated := make(chan interface{})
		go func() {
			defer fmt.Println("doWork exited.")
			defer close(terminated)
			for {
				select {
				case s := <-strings:
					fmt.Println(s)
				case <-done:
					return
				}
			}
		}()
		return terminated
	}

	done := make(chan interface{})
	terminated := doWork(done, nil)

	go func() {
		//在1s之后取消本操作
		time.Sleep(1 * time.Second)
		fmt.Println("Canceling doWork goroutine...")
		close(done)
	}()

	<-terminated
	fmt.Println("Done.")
}

>>Canceling doWork goroutine...
>>doWork exited.
>>Done.

这个例子中,我们加入了两个goroutine,但没有造成死锁。这是因为在我们加入两个goroutine之前,我们创建了第三个goroutine来在doWork执行1s后取消doWork中的goroutine。成功消除了goroutine泄露。

4、如何确保goroutine不泄露?

规定:如果goroutine负责创建goroutine,它也负责确保它可以停止goroutine。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值