go的amt数组算法怎么用
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章主要介绍"go的amt数组算法怎么用",在日常操作中,相信很多人在go的amt数组算法怎么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"go的amt数组算法怎
千家信息网最后更新 2025年02月01日go的amt数组算法怎么用
这篇文章主要介绍"go的amt数组算法怎么用",在日常操作中,相信很多人在go的amt数组算法怎么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"go的amt数组算法怎么用"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
Amt
type Node struct { Bmap []byte //是否设置值 仅第一个字节游泳。八位代表八个自节点是否存在 Links []cid.Cid //自节点 Values []*cbg.Deferred //Flush 将 expVals设置到Values上面 expLinks []cid.Cid //设置的子节点值 expVals []*cbg.Deferred //设置的值 cache []*Node //子节点缓存}
基本结构
amt数据结构是一个八叉树,所有的数据节点都存储在叶子节点上。数组形态就表现在叶子上,把整个树的最底层节点按顺序拼在一起就是amt数组。不存在数据的索引节点会裁减掉,节省所需的数据空间。
设置数据
通过id确定叶子节点位置
如果该叶子节点所在的索引节点有数据,那么直接设置这个数据即可。
如果叶子节点位于当前树容量之内,但是原来不存在该路径数据,需要新建这个索引路径再把数据挂上去。
如果设置的数据位置超过当前八叉树容量,那么先要扩充当前八叉树深度,原数据作为新树的左子树。新节点新建一条路径挂上写入的叶子节点
//增长层数 for i >= nodesForHeight(width, int(r.Height)+1) { if !r.Node.empty() { if err := r.Node.Flush(ctx, r.store, int(r.Height)); err != nil { return err } c, err := r.store.Put(ctx, &r.Node) if err != nil { return err } r.Node = Node{ Bmap: []byte{0x01}, Links: []cid.Cid{c}, } } r.Height++ } //设置值 addVal, err := r.Node.set(ctx, r.store, int(r.Height), i, &cbg.Deferred{Raw: b}) if err != nil { return err } if addVal { r.Count++ }
查找数据
添加数据时候,首先通过高度确定最后一层的数量,在通过数组索引需要确定第一层的索引节点,然后递归,通过倒数第二层的数据宽度确定第二层的索引节点,这样层层找到叶子节点数据
func (n *Node) get(ctx context.Context, bs cbor.IpldStore, height int, i uint64, out interface{}) error { subi := i / nodesForHeight(width, height) set, _ := n.getBit(subi) if !set { return &ErrNotFound{i} } if height == 0 { //找到自节点 n.expandValues() d := n.expVals[i] if um, ok := out.(cbg.CBORUnmarshaler); ok { return um.UnmarshalCBOR(bytes.NewReader(d.Raw)) } else { return cbor.DecodeInto(d.Raw, out) } } subn, err := n.loadNode(ctx, bs, subi, false) if err != nil { return err } return subn.get(ctx, bs, height-1, i%nodesForHeight(width, height), out) //递归向下找自节点}
删除数据
删除数据先查找到数据位置和路径
如果该数据所在的索引节点上还存在其他数据,直接清除数据,设置标识即可。
删除数据之后层层检查索引节点,如果索引节点下面是空的,那么就删除这个空节点。这样可以收缩树的大小防止浪费空间。
如果清除子树后,发现跟节点只存在一个自节点那么可以收缩整棵树的大小,减少高度,进一步减少存储数据的量以及索引的节点数目
func (n *Node) delete(ctx context.Context, bs cbor.IpldStore, height int, i uint64) error { subi := i / nodesForHeight(width, height) set, _ := n.getBit(subi) if !set { return &ErrNotFound{i} } if height == 0 { //找到节点,清理该节点 n.expandValues() n.expVals[i] = nil n.clearBit(i) return nil } subn, err := n.loadNode(ctx, bs, subi, false) if err != nil { return err } //递归向下查找 if err := subn.delete(ctx, bs, height-1, i%nodesForHeight(width, height)); err != nil { return err } if subn.empty() { //清理空枝 n.clearBit(subi) n.cache[subi] = nil n.expLinks[subi] = cid.Undef } return nil}
到此,关于"go的amt数组算法怎么用"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
节点
数据
索引
数组
叶子
算法
学习
位置
路径
递归
二层
大小
容量
所在
更多
空间
结构
高度
子树
存储
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
移动互联网软件开发比赛
观看网络安全读后感500
网络安全法规定收到举报的部门
网络安全防御体系的描述性语句
重庆联通服务器类型虚拟主机
北京宇信易庄网络技术有限公司
软件开发加班好吗
网络安全软件工程
盐田区新一代网络技术开发工艺
中国快递官方数据库
计算机网络技术专升本题库
辽宁网络时间服务器供应商
网络安全最基本的技术
数据库视图使用
昆明计算机软件开发招聘信息
mac mini 服务器
服务器数据网络安全
河东区网络安全应急指挥中心
学计算机网络技术可以兼职吗
网络安全手抄报要简单的大全
网络安全宣传周上海主场
go log数据库
宝塔服务器管理助手安装
软件开发方向个人成长报告
华为软件开发及考后流程
东芝p300私人数据库
网络安全等级测评 山东
电子软件开发过程
贵州奥讯网络技术有限公司
服务器怎么匹配