以太坊MPT简介

MPT(Merkle Patricia Trie)是结合了Trie、Patricia Trie和Merkle Tree的数据结构,用于以太坊的数据存储。它减少了存储空间并加速查找过程。Trie是前缀树,Patricia Trie通过合并只有一个子节点的节点来优化空间。Merkle Tree则用于验证内容完整性。MPT在以太坊中包含四种结点类型:空结点、分支结点、扩展结点和叶子结点,并通过特定方式实现结点的分裂和合并。
摘要由CSDN通过智能技术生成

MPT全称Merkle Patricia Trie,是以太坊用来存储数据的一种数据结构。
MPT融合了Trie、Patricia Trie、Merkle Tree这3种数据结构的优点,从而实现快速查找并节省存储空间。下面依次介绍一下这几种结构的基本概念和原理。

1. Trie

Trie也称为Radix Tree或者Prefix Tree,这个单词来源于retrieval(检索)这个单词的中间4个字母,中文翻译为字典树或者前缀树,是一种用于快速检索的多叉树。
原理很简单,以检索英文单词为例,只需要把每个单词按字母进行拆分然后到树上查找,查找深度和单词的长度相同。下图是一个Trie的示例:
这里写图片描述

2. Patricia Trie

显然,上面这种方式需要耗费较大的存储空间,因为每个结点都必须存储26个指针指向下一级。
实际上我们并没有那么多的单词组合,有一些结点可能只有一个有效child。我们可以把这些只有一个child的结点们合并成一个结点,这就是Patricia Trie。
Patricia这个单词是一个缩写,全称是Practical Algorithm To Retrieve Information Coded In Alphanumeric。下图是一个Patricia Trie的示例:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值