来自以太坊智能合约的交易

问题描述

当我们有合同时,我们转移货币

签名是怎么做的???

比如我给合约发了 10 个以太币,合约分给了 5 个人

这笔交易是怎样的?我的私钥从哪里来签署所有 5 笔交易?

解决方法

我向合约发送了 10 个以太币,合约被 5 个人瓜分

所以可能是这样的:

pragma solidity ^0.8;

contract MyContract {
    function redistribute(address[5] memory otherPeople) external payable {
        for(uint i = 0; i < 5; i++) {
            payable(otherPeople[i]).transfer(msg.value / 5);
        }
    }
}

您向合约发送一笔交易(价值 10 ETH),执行 redistribute() 函数。

合约执行 5 次内部交易,有效地将 2 ETH 转移到每个 otherPeople 地址。

在这种情况下,您只需要使用“主”交易发送方的私钥,因为其他交易都是内部交易,由主交易包裹。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...