合约之间调用-如何实现函数静态调用?

合约之间的函数调用

  • EOA,external owned account,外部账号,例如metamask
  • 调用最终总是由EOA发起的
  • 合约之间的调用使得一次完整的调用成为一个调用链条

合约间调用过程

  • 调用者须持有被调用合约的地址
  • 得到被调用合约的信息
  • 将地址重载为被调用合约,调用它的函数

最直接的调用方式(源文件内部)

  • 调用者直接将被调用合约的地址重载为合约的实例
  • 用合约实例调用合约函数
javascript 复制代码
// SPDX-License-Identifier: GPL-3.0

pragma solidity >=0.8.2 <0.9.0;

contract Callee {
    uint public x;
    function setX(uint _x)public{
        x = _x;
    }
}
contract Caller{
    address calleeAddress;
    constructor(address _calleeAddress){
        calleeAddress = _calleeAddress;
    }
    function setCalleeX(uint _x)public{
        Callee callee = Callee(calleeAddress);
        callee.setX(_x);

    }

}
//0xd9145CCE52D386f254917e481eB44e9943F39138 // Callee合约实例的地址 先部署Callee合约获取地址作为Caller的构造参数

通过import调用合约函数(源文件之间)

  • import被调用合约的源文件
  • 调用者将被调用合约的地址重载为合约实例
  • 用合约实例调用合约函数

Callee.sol

javascript 复制代码
// SPDX-License-Identifier: GPL-3.0

pragma solidity >=0.8.2 <0.9.0;

contract Callee {
    uint public x;
    function setX(uint _x)public{
        x = _x;
    }
}

Caller.sol

javascript 复制代码
// SPDX-License-Identifier: GPL-3.0

pragma solidity >=0.8.2 <0.9.0;
import "./Callee.sol";

contract Caller{
    address calleeAddress;
    constructor(address _calleeAddress){
        calleeAddress = _calleeAddress;
    }
    function setCalleeX(uint _x)public{
        Callee callee = Callee(calleeAddress);
        callee.setX(_x);

    }

}
// 0xd9145CCE52D386f254917e481eB44e9943F39138

通过接口的调用

  • 合约的接口等价于其ABI
  • 接的定义方法
  • 接口的使用方法

ICallee.sol

javascript 复制代码
// SPDX-License-Identifier: GPL-3.0

pragma solidity >=0.8.2 <0.9.0;

interface ICallee {
    function setX(uint _x) external;
    
}

Callee.sol

javascript 复制代码
// SPDX-License-Identifier: GPL-3.0

pragma solidity >=0.8.2 <0.9.0;
// import "./ICallee.sol"; // 柔性,不强制一定要is Icallee 只要实现是一致就行 

// contract Callee is Icallee {
contract Callee {
    uint public x;
      uint public y;
    function setX(uint _x)public{
        x = _x;
    }
    function setY(uint _y)public {
        y=_y;
    }
    //.....
}

Caller.sol

javascript 复制代码
// SPDX-License-Identifier: GPL-3.0

pragma solidity >=0.8.2 <0.9.0;

 interface ICallee {
    function setX(uint _x) external;
    function setY(uint _x) external;
}

contract Caller{
    address calleeAddress;
    constructor(address _calleeAddress){
        calleeAddress = _calleeAddress;
    }
    function setCalleeX(uint _x)public{
        ICallee callee = ICallee(calleeAddress);
        callee.setY(_x);

    }

}
// 0xd9145CCE52D386f254917e481eB44e9943F39138

面向接口

  • 与一般开发语言一样,面向接口而不是实现
  • 不要求被调用者语法上实现一个接口
  • 接口最小化(有必要的才放入接口)
相关推荐
ProgramHan1 小时前
Web3革命——区块链技术重构数字世界的技术逻辑与产业未来
重构·web3·区块链
电报号dapp1193 小时前
Web3实战:从零开发你的ERC20代币合约
web3·去中心化·区块链·智能合约
咨询187150651277 小时前
高企复审奖补!2025年合肥市高新技术企业重新认定奖励补贴政策及申报条件
大数据·人工智能·区块链
电报号dapp11910 小时前
Web3钱包开发功能部署设计
web3·去中心化·区块链·智能合约
云边有个稻草人11 小时前
【金仓数据库征文】从云计算到区块链:金仓数据库的颠覆性创新之路
数据库·云计算·区块链·金仓数据库 2025 征文·数据库平替用金仓·金仓数据库概述·金仓数据库的产品优化提案
拾忆-eleven13 小时前
区块链技术:深入共识算法、智能合约与DApps的架构奥秘
区块链·智能合约·共识算法
倒霉男孩16 小时前
全局变量Msg.sender
区块链
dingzd9521 小时前
Web3区块链网络中数据隐私安全性探讨
web3·区块链·互联网·facebook·tiktok·instagram·clonbrowser
Sui_Network1 天前
全能 Sui 技术栈,构建 Web3 的未来
人工智能·物联网·游戏·web3·区块链·智能合约
码上飞扬2 天前
用Java实现简易区块链:从零开始的探索
java·区块链·哈希算法