我正在玩一个私有的以太坊区块链,我对实施一些智能合约很感兴趣。但是,信息非常有限,因为这是区块链的较新实现。
举个例子,假设我想要一份包含个人信息的合同。为每个人创建一个新合约,还是简单地在同一个合约中保存所有用户的信息,是否更有效?
在伪代码中,这两个选项如下所示。
选项 1(为每个人实例化一个新合同):
contract = // contract code
ethereum.newContract(contract, userInfo);
选项 2(在一份合约中保存所有用户的信息):
contract = {
var users = [];
// other contract code
}
ethereum.newContract(contract, userInfo);
在这种情况下,我们可以通过以下方式量化“效率”:
每次实例化新合约时,我们都必须为合约挖掘区块,然后挖掘用户对合约进行的任何交易。然而,如果我们只实例化一个合约,我们只挖掘合约部署一次,然后是之后的任何交易,但是......
如果我们选择将所有用户的所有信息存储在一个合约中,则只是将合约数据的“差异”(所有用户的“数组”)存储为一个块,或者将整个数据集存储在每个街区?或者...
如果我们选择“每个用户的合同”选项,如果我们多次存储整个合同定义,是否会“浪费空间”(是否值得进行可能的冗余挖掘)?
希望我的问题很清楚,但如果没有,请告诉我。我相信这个问题是“权衡”之一。
(回复:标签——我使用以太坊的 golang 实现,以及一个 JavaScript API 与之交互。)
叮当猫咪
慕田峪4524236
相关分类