sync.Pool的使用

一定要搞明白sync.Pool的正确用法,避免出现以下问题:

            kline := this.pool.Get()
            defer this.pool.Put(kline)
            kline.UnMarshal(data)
            select {
            case this.chKLine <- &kline:
            }

其中,this.chKLine是带缓冲的channnel。问题在于,写入缓冲channel后就将对象put归还了,这个对象会被重新使用/赋值,而缓冲channel中该数据可能还没有处理完毕。

猜你喜欢

转载自www.cnblogs.com/cqvoip/p/9038095.html