2020-07-26 17:09:05 +08:00
|
|
|
package threading
|
|
|
|
|
|
|
|
import (
|
2020-08-08 16:40:10 +08:00
|
|
|
"github.com/tal-tech/go-zero/core/lang"
|
|
|
|
"github.com/tal-tech/go-zero/core/rescue"
|
2020-07-26 17:09:05 +08:00
|
|
|
)
|
|
|
|
|
2021-02-26 16:27:04 +08:00
|
|
|
// A TaskRunner is used to control the concurrency of goroutines.
|
2020-07-26 17:09:05 +08:00
|
|
|
type TaskRunner struct {
|
|
|
|
limitChan chan lang.PlaceholderType
|
|
|
|
}
|
|
|
|
|
2021-02-26 16:27:04 +08:00
|
|
|
// NewTaskRunner returns a TaskRunner.
|
2020-07-26 17:09:05 +08:00
|
|
|
func NewTaskRunner(concurrency int) *TaskRunner {
|
|
|
|
return &TaskRunner{
|
|
|
|
limitChan: make(chan lang.PlaceholderType, concurrency),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-26 16:27:04 +08:00
|
|
|
// Schedule schedules a task to run under concurrency control.
|
2020-07-26 17:09:05 +08:00
|
|
|
func (rp *TaskRunner) Schedule(task func()) {
|
|
|
|
rp.limitChan <- lang.Placeholder
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
defer rescue.Recover(func() {
|
|
|
|
<-rp.limitChan
|
|
|
|
})
|
|
|
|
|
|
|
|
task()
|
|
|
|
}()
|
|
|
|
}
|