明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 95|回复: 1

跳表+Intel TSX事务内存

[复制链接]
发表于 昨天 17:02 | 显示全部楼层 |阅读模式
本帖最后由 你有种再说一遍 于 2025-4-15 19:14 编辑

索引分布不均:
由于跳表生成的索引是随机的,
搜索时候定位到最下层之后,还有一个线性扫描,
这个线性扫描会随着跳表不断插入而增加,尤其是到了后段.

方案一:
通过动态晋升概率来优化.

方案二:
利用SIMD提速这个线性扫描.

需要利用节点固定大小到SIMD长度,从而降低这种索引分布不均的代价.
那么可以利用SIMD要求的定长,随机把生成索引定位在128/256位置,
此时在上百亿个key就可以充分利用SIMD了.

你可以发现这些方式下,除非特别长的跳表,
否则速度仍然是取决于随机跳跃.

由于块内是连续的,竞争插入同一个块的多线程仍然耗时,
因为插入块内需要锁块.
此时定制硬件就显得重要了,
如果有一个原子性的话...

然后我就去找资料,发现嘿嘿,还真有.
若硬件支持原子性操作SIMD数组(如Intel TSX事务内存)
可进一步减少锁开销.
然后发现了AMD居然没这个,看来通用性不大,
难怪没有成为跳表的基础
回复

使用道具 举报

发表于 24 分钟前 | 显示全部楼层
很深的研究咯
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-4-16 09:26 , Processed in 0.172608 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表