forked from mirror/ants
Avoid memory leak (#107)
This commit is contained in:
parent
21f632368a
commit
ef60172172
1
pool.go
1
pool.go
|
@ -81,6 +81,7 @@ func (p *Pool) purgePeriodically() {
|
|||
// are located on non-local CPUs.
|
||||
for i := range expiredWorkers {
|
||||
expiredWorkers[i].task <- nil
|
||||
expiredWorkers[i] = nil
|
||||
}
|
||||
|
||||
// There might be a situation that all workers have been cleaned up(no any worker is running)
|
||||
|
|
|
@ -68,6 +68,7 @@ func (wq *loopQueue) detach() *goWorker {
|
|||
}
|
||||
|
||||
w := wq.items[wq.head]
|
||||
wq.items[wq.head] = nil
|
||||
wq.head++
|
||||
if wq.head == wq.size {
|
||||
wq.head = 0
|
||||
|
@ -90,6 +91,7 @@ func (wq *loopQueue) retrieveExpiry(duration time.Duration) []*goWorker {
|
|||
break
|
||||
}
|
||||
wq.expiry = append(wq.expiry, wq.items[wq.head])
|
||||
wq.items[wq.head] = nil
|
||||
wq.head++
|
||||
if wq.head == wq.size {
|
||||
wq.head = 0
|
||||
|
|
|
@ -35,6 +35,7 @@ func (wq *workerStack) detach() *goWorker {
|
|||
}
|
||||
|
||||
w := wq.items[l-1]
|
||||
wq.items[l-1] = nil // avoid memory leaks
|
||||
wq.items = wq.items[:l-1]
|
||||
|
||||
return w
|
||||
|
@ -53,6 +54,9 @@ func (wq *workerStack) retrieveExpiry(duration time.Duration) []*goWorker {
|
|||
if index != -1 {
|
||||
wq.expiry = append(wq.expiry, wq.items[:index+1]...)
|
||||
m := copy(wq.items, wq.items[index+1:])
|
||||
for i := m; i < n; i++ {
|
||||
wq.items[i] = nil
|
||||
}
|
||||
wq.items = wq.items[:m]
|
||||
}
|
||||
return wq.expiry
|
||||
|
@ -74,6 +78,7 @@ func (wq *workerStack) binarySearch(l, r int, expiryTime time.Time) int {
|
|||
func (wq *workerStack) reset() {
|
||||
for i := 0; i < wq.len(); i++ {
|
||||
wq.items[i].task <- nil
|
||||
wq.items[i] = nil
|
||||
}
|
||||
wq.items = wq.items[:0]
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue