"A", "to", "tea", "ted", "ten", "i", "in", "inn" 这些单词组成的字典树.code
基数树与字典树的区别在于基数树将单词压缩了, 节点变得更少blog
单词 "BANANA" 的后缀树
. 每一个后缀以 $ 结尾
. 全部的后缀为 A$
, NA$
, ANA$
,NANA$
, ANANA$
and BANANA$
. 叶子节点表示后缀的起始坐标. 世界上后缀树就是一个单词的全部后缀组成的字典树, 而且把字典树单词进行了压缩队列
在咱们的消息队列中, 须要根据消息的 subject 查找全部订阅了该 subject 的 group, consumer 订阅 subject 方式是经过订阅 subject 的前缀, 例如 subject 为 flight.book.pay 能够经过订阅前缀 flight.book 来接收消息. 在咱们的应用中, 使用 concurrent-tree 的 ConcurrentInvertedRadixTree 来存储 prefix => Map<String, Group>. 也就是 前缀 => Map<Group name, Group>.get
在查询的时候, 经过 tree.getKeysPrefixing(subject) 来查找订阅了 subject 的 group消息队列