队列

今天我们来简单介绍一下队列这种数据结构,根据维基百科的定义,队列是这样一种数据结构:

In computer science, a queue is a collection of entities that are maintained in a sequence and can be modified by the addition of entities at one end of the sequence and removal from the other end of the sequence.

所以说,队列的特点就是,数据往一个方向流动,就像是一根水管,我们从一端注水,水从另一端流出。

队列的实际使用

那么日常项目中什么地方会用到队列呢?我们想想带队列的名词:消息队列、任务队列。没错,他们就是队列。而实现一个最简单的 消息队列可以用Redis中的list,我们需要两个命令:RPUSH和BLPOP。前者的作用是将任务塞入队列,后者的作用是从队列中弹出一个 任务。如Python-RQ源码分析 中所说,借助BLPOP 命令:

@classmethod
def lpop(cls, queue_keys, timeout, connection=None):
    connection = resolve_connection(connection)
    if timeout is not None:  # blocking variant
        if timeout == 0:
            raise ValueError('RQ does not support indefinite timeouts. Please pick a timeout value > 0')
        result = connection.blpop(queue_keys, timeout)
    ...

总结

这一篇中我们介绍了队列的特性,以及队列在实际项目中的应用。


参考资料:


微信公众号
关注公众号,获得及时更新

更多文章
  • Golang context源码阅读与分析
  • Golang中的并发控制
  • 善用闭包(closure)让Go代码更优雅
  • Golang的可选参数实践
  • FreeBSD ipfw使用教程
  • Golang expvar库源码阅读
  • Golang SQL生成库 Squirrel 教程及源码阅读
  • Golang validator使用教程
  • 使用Redis的Stream模块实现群聊功能
  • 价值编程与职业发展
  • 解决k8s cron无法读取环境变量的问题
  • 应用内购的坑
  • 两种常见的访问控制模型
  • gunicorn max-requests 选项的作用
  • Redis使用中的几点注意事项