解惑:关于 gin 的路由实现,前缀树?map?

tpkeeper · 2019-06-12 22:26:05 · 4298 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2019-06-12 22:26:05 的主题,其中的信息可能已经有所发展或是发生改变。

复杂度

  • 前缀树 O(n)
  • map O(1)

从复杂度上看 前缀树 是大于 map 的

那么gin使用前缀树只是为了降低内存占用吗?


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

4298 次点击  
加入收藏 微博
6 回复  |  直到 2019-06-14 15:18:39
tpkeeper
tpkeeper · #1 · 6年之前

没有人讨论吗

tpkeeper
tpkeeper · #2 · 6年之前

没人?

tpkeeper
tpkeeper · #3 · 6年之前

deletelazy
deletelazy · #4 · 6年之前

一方面是节省内存,更重要是方便查找,像/user/:id这种参数会变的路由用map就不太好实现了

deletelazy
deletelazy · #5 · 6年之前

像下面这种场景,map也不太好实现

为了更具扩展性,每一层的节点按照priority排序,priority是节点的子节点(儿子节点,孙子节点等)注册的handler的数量,这样做有两个好处:

  • 被最多路径包含的节点会被最先评估。这样可以让尽量多的路由快速被定位。
  • 有点像成本补偿。最长的路径可以被最先评估,补偿体现在最长的路径需要花费更长的时间来定位,如果最长路径的节点能被优先评估(即每次拿子节点都命中),那么所花时间不一定比短路径的路由长。下面展示了节点(每个-可以看做一个节点)评估的路径:从左到右,从上到下

可以看下这篇文章,讲得挺好的 路由查找之Radix Tree

tpkeeper
tpkeeper · #6 · 6年之前
deletelazydeletelazy #4 回复

一方面是节省内存,更重要是方便查找,像`/user/:id`这种参数会变的路由用`map`就不太好实现了

感谢

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传