mirror of
https://github.com/zeromicro/go-zero.git
synced 2025-01-26 11:28:46 +08:00
32 lines
650 B
Go
32 lines
650 B
Go
package threading
|
|
|
|
import (
|
|
"github.com/tal-tech/go-zero/core/lang"
|
|
"github.com/tal-tech/go-zero/core/rescue"
|
|
)
|
|
|
|
// A TaskRunner is used to control the concurrency of goroutines.
|
|
type TaskRunner struct {
|
|
limitChan chan lang.PlaceholderType
|
|
}
|
|
|
|
// NewTaskRunner returns a TaskRunner.
|
|
func NewTaskRunner(concurrency int) *TaskRunner {
|
|
return &TaskRunner{
|
|
limitChan: make(chan lang.PlaceholderType, concurrency),
|
|
}
|
|
}
|
|
|
|
// Schedule schedules a task to run under concurrency control.
|
|
func (rp *TaskRunner) Schedule(task func()) {
|
|
rp.limitChan <- lang.Placeholder
|
|
|
|
go func() {
|
|
defer rescue.Recover(func() {
|
|
<-rp.limitChan
|
|
})
|
|
|
|
task()
|
|
}()
|
|
}
|