以太坊RPC之getBalance调用流程分析

以下是RPC客户端调用getBalance的时序图:

以太坊RPC之getBalance调用流程分析_第1张图片

主要流程:

1:通过区块高度从HeaderChain中获得header,header的数据以RLP格式保存在DatabaseReader这个接口中(实现类是。。)

2:通过header.root从Database这个接口(实现类是。。)中获得trie,从而构造出stateDB

问题:获得trie后,再通过address,可直接获得此地址的account,然后便可直接获得balance,就不需要下面这么多步了,不知后续额外流程的用意何在...

3:通过address从stateDB中获得stateObject,而stateobject由stateDB,address和account三个对象组成,前两个已知,最后一个account是根据address从trie中获得的,而trie就是第2步中构造stateDB时传进去的(这也是上面问题所在)

4:从stateObject中的account中获得这个address的balance。

关键信息解读:

1:HeaderChain中所有header的信息保存在接口DatabaseReader的实现类中

2:trie的信息保存在DataBase接口中,通过header中的root值便可获得对应的trie

3:trie中保存了每个账户的信息,通过address便可获得trie中对应的账户

4:通过此调用流程,还未看出stateDB和stateObject的具体用途,留待后续分析

你可能感兴趣的:(区块链之以太坊)