123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- package syncx
- import (
- "errors"
- "github.com/tal-tech/go-zero/core/lang"
- )
- // ErrLimitReturn indicates that the more than borrowed elements were returned.
- var ErrLimitReturn = errors.New("discarding limited token, resource pool is full, someone returned multiple times")
- // Limit controls the concurrent requests.
- type Limit struct {
- pool chan lang.PlaceholderType
- }
- // NewLimit creates a Limit that can borrow n elements from it concurrently.
- func NewLimit(n int) Limit {
- return Limit{
- pool: make(chan lang.PlaceholderType, n),
- }
- }
- // Borrow borrows an element from Limit in blocking mode.
- func (l Limit) Borrow() {
- l.pool <- lang.Placeholder
- }
- // Return returns the borrowed resource, returns error only if returned more than borrowed.
- func (l Limit) Return() error {
- select {
- case <-l.pool:
- return nil
- default:
- return ErrLimitReturn
- }
- }
- // TryBorrow tries to borrow an element from Limit, in non-blocking mode.
- // If success, true returned, false for otherwise.
- func (l Limit) TryBorrow() bool {
- select {
- case l.pool <- lang.Placeholder:
- return true
- default:
- return false
- }
- }
|