合约之间调用-如何实现函数静态调用?
创始人
2024-12-28 09:37:04
0

合约之间的函数调用

在这里插入图片描述

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

合约间调用过程

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

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

  • 调用者直接将被调用合约的地址重载为合约的实例
  • 用合约实例调用合约函数
// 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

// 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

// 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

// SPDX-License-Identifier: GPL-3.0  pragma solidity >=0.8.2 <0.9.0;  interface ICallee {     function setX(uint _x) external;      } 

Callee.sol

// 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

// 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 

面向接口

  • 与一般开发语言一样,面向接口而不是实现
  • 不要求被调用者语法上实现一个接口
  • 接口最小化(有必要的才放入接口)

相关内容

热门资讯

四分钟体悟!皇豪互娱辅助器下载... 四分钟体悟!皇豪互娱辅助器下载!(透视)外挂开挂辅助透视挂(2020已更新)-哔哩哔哩是一款可以让一...
两分钟了解!中至乐平麻将可以设... 两分钟了解!中至乐平麻将可以设置输赢的!(透视)外挂辅助器神器(2021已更新)-哔哩哔哩;亲,有的...
C++相关概念和易错语法(20... 1.赋值兼容转换赋值兼容转换有一点易混,先看一下下面的代码,想想a、b、...
两分钟掌握!老胡麻将赢牌技巧!... 两分钟掌握!老胡麻将赢牌技巧!(透视)外挂开挂辅助脚本(2024已更新)-哔哩哔哩是一款可以让一直输...
5分钟掌握!jj斗地主脚本购买... 5分钟掌握!jj斗地主脚本购买!(透视)外挂开挂辅助作弊(2023已更新)-哔哩哔哩是一款可以让一直...
二分钟掌握!威信茶馆有辅助的!... 二分钟掌握!威信茶馆有辅助的!(透视)外挂辅助作弊(2020已更新)-哔哩哔哩是一款可以让一直输的玩...
两分钟了解!山西扣点有猫腻!(... 自定义新版山西扣点有猫腻系统规律,只需要输入自己想要的开挂功能,一键便可以生成出山西扣点有猫腻专用辅...
两分钟体悟!掌中乐外挂!(透视... 两分钟体悟!掌中乐外挂!(透视)外挂开挂辅助器神器(2023已更新)-哔哩哔哩是一款可以让一直输的玩...
两分钟掌握!情怀麻将控牌器!(... 两分钟掌握!情怀麻将控牌器!(透视)外挂开挂辅助器神器(2020已更新)-哔哩哔哩;1、很好的工具软...
七分钟秒懂!微信决胜麻将免费软... 七分钟秒懂!微信决胜麻将免费软件!(透视)外挂开挂辅助开挂(2021已更新)-哔哩哔哩;AI智能教程...