队列的最主要用途是异步任务和通信两个方面。
异步的思路主要用来缓解瞬间压力、耗时操作、并行任务等。
1. 缓解瞬间压力:若系统每秒处理能力是100请求,而最高峰值可能达到每秒1000请求,若不采用队列,很有可能会出现服务不可用或者长时间等待。此时可以用队列将未能成功执行的请求放入队列,顺序执行,直到所有请求都被处理。
2. 耗时操作:如@loki 提到的缩略图生成。
3. 并行任务:如在发贴后分发通知所有的好友。
通信的思路主要用来解决在不同的独立模块或者系统之间相互同步数据、通知执行某些操作等。如@loki提到的发贴同步百度贴吧。