golang 线程安全队列 读取函数带超时功能

type Deque struct {
    sync.RWMutex
    notEmptyNotify        chan int 
    container *list.List
}
func (s *Deque) Put(item interface{}) {
    s.Lock()
    s.container.PushFront(item)
    s.Unlock()
    select {
    case s.notEmptyNotify <-1:
    default:
    }   
}
func (s *Deque) Get(timeout int) (interface{}, error) {
    s.Lock()
    var item interface{} = nil
    var lastContainerItem *list.Element = nil
    endTime := time.Now().Add(time.Duration(timeout) * time.Second)
    for {
        if s.container.Back() != nil {
            break
        }
        remaining := endTime.Sub(time.Now())
        s.Unlock()
        if remaining < 0 {
            return nil, errors.New("time out in Get")
        }
        select {
        case <-s.notEmptyNotify:
        case <-time.After(remaining):
        return nil, errors.New("time out in Get")
        }
        s.Lock()
    }
    lastContainerItem = s.container.Back()
    item = s.container.Remove(lastContainerItem)
    s.Unlock()
    return item, nil
}

 
queueFreeServer := Deque{ container: list.New(),  notEmptyNotify: make(chan int)}

最近提供人像分割服务给业务方时, 发现需要有一个服务分发请求, 开始用python flask框架发现问题挺多, 用golang重写时发现网上实现的golang版队列, 都没有像python那样的Get超时功能. 于是结合网上代码和python queue代码自己写了一个, 看来golang还没完全忘记.

队列不支持设定固定size, 队列满时Put等待和Put超时, 需要的朋友可以自己扩展一下.

github地址: https://github.com/bolun365/golang-queue.git

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值