设计一个路由

简单地说一下常见的路由形式。

  • 数组存储。按照添加路由的顺序存储在数组中,查找时依次匹配。这种路由效率比较低。tornado就是这么设计的。

  • 字典存储。把路由存储在map里,查找效率很高,但是不支持URI中有参数。Golang中默认的mux就这么设计的。

  • 树。一般使用前缀树,空间更紧凑的用radix tree。如 httprouter 就是这种设计。

一般就这么几种,可能会有些许细节上的不同。


更多文章
  • Redis源码阅读:bitmap 位图的运算
  • Redis源码阅读:set是怎么做交并集运算的?
  • Redis源码阅读:list实现(ziplist, quicklist)
  • Redis源码阅读:RDB是怎么实现的
  • Redis源码阅读:AOF重写
  • Redis源码阅读:AOF持久化
  • Redis源码阅读:key是怎么过期的
  • Redis源码阅读:字典是怎么实现的
  • Redis源码阅读:执行命令
  • Redis源码阅读:启动过程
  • WAL(Write-ahead logging)的套路
  • 搞定CORS问题
  • 如何定位程序问题所在
  • 设计一个IM归档系统
  • logrotate read only filesystem问题