ethereumjs/merkle-patricia-tree-2-API
SecureTrie
Extends Trie 扩展前缀树
You can create a secure Trie where the keys are automatically hashed using SHA3 by using require('merkle-patricia-tree/secure'). It has the same methods and constructor as Trie.
你可以通过使用require('merkle-patricia-tree/secure')创建一个keys会自动使用SHA3进行hash的安全前缀树。它有着与Trie相同的方法和构造函数
Trie
Use require('merkel-patricia-tree') for the base interface. In Ethereum applications stick with the Secure Trie Overlay require('merkel-patricia-tree/secure'). The API for the raw and the secure interface are about the same
使用require('merkel-patricia-tree')获取基本接口。在Ethereum应用程序坚持使用安全的Trie,即require('merkel-patricia-tree/secure')。对于原始的和安全的Trie的接口的API是相同的。
Parameters参数
dbObject? An instance of levelup or a compatible API. If the db isnullor left undefined, then the trie will be stored in memory via memdown levelup实例或一个兼容API。如果db为null或undefined,那么trie将通过memdown存储到内存中root(Buffer | String)? A hexStringorBufferfor the root of a previously stored trie 以前存储的trie的根,为一个十六进制字符串或buffer
Properties属性
rootBuffer The current root of thetrie 当前trie的根isCheckpointBoolean determines if you are saving to a checkpoint or directly to the db 决定是保存到检查点还是直接保存到数据库EMPTY_TRIE_ROOTBuffer the Root for an empty trie 空trie的根
get
Gets a value given a key
得到给定key的value
Parameters参数
key(Buffer | String) the key to search for 搜索的keycbFunction A callbackFunctionwhich is given the argumentserr- for errors that may have occured andvalue- the found value in aBufferor if no value was foundnull 有给定参数err-可能发生的错误和value-在Buffer中发现的value,如果没有则为null的回调函数
put
Stores a given value at the given key
在给定的key上存储给定的value
Parameters参数
key(Buffer | String)Value(Buffer | String)cbFunction A callbackFunctionwhich is given the argumenterr- for errors that may have occured 有给定参数err-可能发生的错误的回调函数
del
deletes a value given a key
删除给定key的value
Parameters
getRaw
Retrieves a raw value in the underlying db
检索底层数据库中的原始value
Parameters
keyBuffercallbackFunction A callbackFunction, which is given the argumentserr- for errors that may have occured andvalue- the found value in aBufferor if no value was foundnull.有给定参数err-可能发生的错误和value-在Buffer中发现的value,如果没有则为null的回调函数
putRaw
Writes a value directly to the underlining db
直接将value写入底层数据库
Parameters
key(Buffer | String) The key as aBufferorString Buffer或String类型的keyvalueBuffer The value to be stored 存储的valuecallbackFunction A callbackFunction, which is given the argumenterr- for errors that may have occured 有给定参数err-可能发生的错误的回调函数
delRaw
Removes a raw value in the underlying db
移除在底层数据库中的原始数据
Parameters
key(Buffer | String)callbackFunction A callbackFunction, which is given the argumenterr- for errors that may have occured有给定参数err-可能发生的错误的回调函数
findPath
Trys to find a path to the node for the given key It returns a stack of nodes to the closet node
根据给定key尝试找到node的path。其返回到最近节点node的nodes的堆栈
Parameters参数
null-null(String | Buffer) key - the search key 搜索keynull-nullFunction cb - the callback function. Its is given the following arguments回调函数,给定以下参数- err - any errors encontered 遇见的错误
- node - the last node found 最后找到的节点node
- keyRemainder - the remaining key nibbles not accounted for 剩余的没有找到半个字节的key
- stack - an array of nodes that forms the path to node we are searching for 一个节点数组,它构成我们正在搜索的节点的路径
createReadStream
The data event is given an Object hat has two properties; the key and the value. Both should be Buffers.
data事件给了带有两个属性的对象:key和value,都为Buffer类型
Returns stream.Readable Returns a stream of the contents of the trie
返回类型是stream.Readable ,返回trie内容的流
batch
The given hash of operations (key additions or deletions) are executed on the DB
给定的要执行在数据库上的操作(key添加或删除)的hash
Parameters
Examples
var ops = [
{ type: 'del', key: 'father' }
, { type: 'put', key: 'name', value: 'Yuri Irsenovich Kim' }
, { type: 'put', key: 'dob', value: '16 February 1941' }
, { type: 'put', key: 'spouse', value: 'Kim Young-sook' }
, { type: 'put', key: 'occupation', value: 'Clown' }
]
trie.batch(ops)
checkRoot
Checks if a given root exists
检查给定的root是否存在
Parameters
Merkle Proof Merkle证明
Static functions for creating/verifying a merkle proof.
创建/验证Merkle证明的静态函数
prove
Returns a merkle proof for a given key
根据给定key返回merkle证明
Parameters
trieTriekeyStringcbFunction A callbackFunction(arguments {Error}err, {Array.}proof) 回调函数fun(err,proof)
verifyProof
Verifies a merkle proof for a given key
根据给定key验证merkle证明
Parameters
rootHashBufferkeyStringproofArray<TrieNode>cbFunction A callbackFunction(arguments {Error}err, {String}val) 回调函数fun(err,val)
Internal Util Functions 内部Util函数
These are not exposed.这些函数是不暴露给外部用户的
addHexPrefix
Parameters
keyterminatordataArrArray
Returns Buffer returns buffer of encoded data hexPrefix *
返回类型为Buffer,返回添加了十六进制前缀的编码数据的buffer
asyncFirstSeries
Take a collection of async fns, call the cb on the first to return a truthy value. If all run without a truthy result, return undefined
异步函数的收集,调用第一个参数上的回调返回可信value。如果所有运行没有可信结果,返回undefined
Parameters
arrayiteratorcb
callTogether
Take two or more functions and returns a function that will execute all of the given functions
调用两个或更多函数,然后返回一个执行所有给定函数的函数
doKeysMatch
Compare two 'nibble array' keys
比较两个半字节数组keys
Parameters
keyAkeyB
ethereumjs/merkle-patricia-tree-2-API的更多相关文章
- 014-数据结构-树形结构-基数树、Patricia树、默克尔树、梅克尔帕特里夏树( Merkle Patricia Tree, MPT)
一.基数树 Radix树,即基数树,也称压缩前缀树,是一种提供key-value存储查找的数据结构.与Trie不同的是,它对Trie树进行了空间优化,只有一个子节点的中间节点将被压缩.同样的,Radi ...
- Merkle Patricia Tree (MPT) 树详解
1. 介绍 Merkle Patricia Tree(简称MPT树,实际上是一种trie前缀树)是以太坊中的一种加密认证的数据结构,可以用来存储所有的(key,value)对.以太坊区块的头部包 ...
- Merkle Patricia Tree (MPT) 以太坊中的默克尔树
本篇博文是自己学习mpt的过程,边学边记录,很多原理性内容非自己原创,好的博文将会以链接形式进行共享. 一.什么是mpt MPT是以太坊中的merkle改进树,基于基数树,即前缀树改进而来,大大提高了 ...
- 使用 Jackson 树模型(tree model) API 处理 JSON
http://blog.csdn.net/gao1440156051/article/details/54091702 http://blog.csdn.net/u010003835/article/ ...
- Merkle Tree学习
/*最近在看Ethereum,其中一个重要的概念是Merkle Tree,以前从来没有听说过,所以查了些资料,学习了Merkle Tree的知识,因为接触时间不长,对Merkle Tree的理解也不是 ...
- Merkle Tree 概念
Merkle Tree 概念 来源 https://www.cnblogs.com/fengzhiwu/p/5524324.html /*最近在看Ethereum,其中一个重要的概念是Merkle T ...
- Merkle Tree(默克尔树)算法解析
Merkle Tree概念 Merkle Tree,通常也被称作Hash Tree,顾名思义,就是存储hash值的一棵树.Merkle树的叶子是数据块(例如,文件或者文件的集合)的hash值.非叶节点 ...
- 转 Merkle Tree(默克尔树)算法解析
Merkle Tree概念 Merkle Tree,通常也被称作Hash Tree,顾名思义,就是存储hash值的一棵树.Merkle树的叶子是数据块(例如,文件或者文件的集合)的hash值.非叶节 ...
- 区块链~Merkle Tree(默克尔树)算法解析~转载
转载~Merkle Tree(默克尔树)算法解析 /*最近在看Ethereum,其中一个重要的概念是Merkle Tree,以前从来没有听说过,所以查了些资料,学习了Merkle Tree的知识,因为 ...
- ethereumjs/merkle-patricia-tree-1-简介
https://github.com/ethereumjs/merkle-patricia-tree SYNOPSIS概要 This is an implementation of the modif ...
随机推荐
- linux的日常经常使用的命令
现在经常用到linux命令,又时候回忘记,我就做个小笔记,大家也可以补充补充.....可以评论一下,我会截图做笔记的 netstat -ntlp //查看当前系统进程和端口等信息 tail -f fi ...
- 安装vmware player
一.简介 什么是虚拟机? 虚拟机是通过软件来模拟一个完整的计算机系统.简单来说,你可以在当前系统中通过虚拟机软件运行另外一个系统,并且与当前系统隔离. 什么是vmware? vmware(virtua ...
- 11、springboot之包扫描
如上图,将Application启动类放入hello.aaa文件夹下面 启动springboot,访问http://localhost:9999/testJson,报404错误,在启动类上面加上@Co ...
- K:大数加法
相关介绍: 在java中,整数是有最大上限的.所谓大数是指超过整数最大上限的数,例如18 452 543 389 943 209 789 324 233和8 123 534 323 432 323 ...
- 数组的filter()方法
filter()也是一个用的不多的方法,但有时候还是比较有用的: 首先,Array.filter()是数组的方法,它作为数组方法被调用,传入一个callback,返回Array中符合callback条 ...
- JS实现图片放大镜
将一个小图放置在一个小盒子里,当鼠标在小盒子里移动时,出现一个移动块,右侧出现一个大盒子,显示出小盒子中移动块所在区域的等比例放大的图片内容.需要实现的效果如下: 基本实现思路为:右侧大盒子为一个可视 ...
- 为什么排版引擎解析 CSS 选择器时一定要从右往左解析?
首先我们要看一下选择器的「解析」是在何时进行的. 主要参考这篇「 How browsers work」(http://taligarsiel.com/Projects/howbrowserswork1 ...
- [转载]一步一步教你如何在Virtualbox虚拟机中安装Remix
原文地址:https://bbs.jide.com/forum.php?mod=viewthread&tid=4892 大神请路过-- [准备工具] 1.Virtualbox虚拟机(这个是免费 ...
- minimal sparse ruler problem 最少尺子刻度问题
一个长度13的尺子,如果在1位置刻点可以量出1和12,13三种刻度.那么至少刻几个点,可以直接量出1-13所有的长度,分别刻在哪几个位置? 注:必须是直接量.即在尺子上能找出一个1-13任意的整数长度 ...
- 一、C#简单读写
using System.IO; static string configFileName = "config.json"; //不存在就直接新建文件夹 public static ...