首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >比较数组的有效方法

比较数组的有效方法
EN

Ethereum用户
提问于 2019-06-16 15:30:23
回答 2查看 397关注 0票数 0

什么是最具成本效益的方法来比较数组,例如。坚固的uint数组。运行一个for循环需要太多的气体。

EN

回答 2

Ethereum用户

发布于 2019-06-16 17:12:02

我怀疑for循环是最有效的方法。但取决于你在做什么,也许你可以把工作从链子上做出来。

例如,假设有两个用户: Alice和Bob。还有两个数组: array1和array2。如果这两个数组相等,则应向Alice支付一定金额。如果这两个数组不相等,则应向Bob支付一定金额。聪明的合同逻辑现在可以很简单了:默认情况下,Alice在24小时后就能拿到工资。如果Bob想得到报酬,他必须在智能契约中调用一个函数,告诉它这两个数组的哪个元素是不同的。聪明的合同可以很容易地在固定时间内证实这一点,如果鲍勃说的是实话,他就会付钱给他。

票数 1
EN

Ethereum用户

发布于 2019-06-16 15:52:17

如果两个数组不是相同的集合,但是某些元素是相同的,那么唯一的方法是循环,如果您想比较两个数组,也就是相同的集合,可以使用两个数组的keccak256比较:keccak256(abi.encodePacked((a))) == keccak256(abi.encodePacked((b)));

但是,如果您想检查相同的元素,那么为什么不使用视图并返回结果,因为它不会改变块链的状态,所以它不会接受eth。

票数 -2
EN
页面原文内容由Ethereum提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://ethereum.stackexchange.com/questions/71912

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档