mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-02 03:40:27 +08:00
57 lines
970 B
Go
57 lines
970 B
Go
// Copyright 2023 GoEdge CDN goedge.cdn@gmail.com. All rights reserved. Official site: https://goedge.cloud .
|
|
|
|
package taskutils
|
|
|
|
import (
|
|
"errors"
|
|
"reflect"
|
|
"sync"
|
|
)
|
|
|
|
func RunConcurrent(tasks any, concurrent int, f func(task any)) error {
|
|
if tasks == nil {
|
|
return nil
|
|
}
|
|
var tasksValue = reflect.ValueOf(tasks)
|
|
if tasksValue.Type().Kind() != reflect.Slice {
|
|
return errors.New("ony works for slice")
|
|
}
|
|
|
|
var countTasks = tasksValue.Len()
|
|
if countTasks == 0 {
|
|
return nil
|
|
}
|
|
|
|
if concurrent <= 0 {
|
|
concurrent = 8
|
|
}
|
|
if concurrent > countTasks {
|
|
concurrent = countTasks
|
|
}
|
|
|
|
var taskChan = make(chan any, countTasks)
|
|
for i := 0; i < countTasks; i++ {
|
|
taskChan <- tasksValue.Index(i).Interface()
|
|
}
|
|
|
|
var wg = &sync.WaitGroup{}
|
|
wg.Add(concurrent)
|
|
for i := 0; i < concurrent; i++ {
|
|
go func() {
|
|
defer wg.Done()
|
|
|
|
for {
|
|
select {
|
|
case task := <-taskChan:
|
|
f(task)
|
|
default:
|
|
return
|
|
}
|
|
}
|
|
}()
|
|
}
|
|
wg.Wait()
|
|
|
|
return nil
|
|
}
|