solidity-21-call_contract

调用其他合约

练笔时刻,首先创建一个合约用于被其他合约调用

javascript 复制代码
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.21;

contract othercontract{
    // 定义一个只有自己能访问的参数
    uint256 private _x = 0;
    event log(uint amount,uint gas);

    function getbalance() public view returns (uint _balance){
        _balance = address(this).balance;
    }


    // 消息会携带value 所以需要标注为payable
    function setx(uint256 x) external payable {
        _x = x;
        if(msg.value > 0){
            emit log(msg.value, gasleft());
        } 
    }

    // 返回这个_x,私有参数可以通过方法进行访问但不能直接访问
    function get_x() public view returns(uint x){
        x = _x;
    }
}

那么如何调用这个合约呢?

我们可以利用合约的地址和合约代码(或接口)来创建合约的引用:_Name(_Address),其中_Name是合约名,应与合约代码(或接口)中标注的合约名保持一致,_Address是合约地址。然后用合约的引用来调用它的函数:_Name(_Address).f(),其中f()是要调用的函数。

javascript 复制代码
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.21;

contract othercontract{
    // 定义一个只有自己能访问的参数
    uint256 private _x = 0;
    event log(uint amount,uint gas);

    function getbalance() public view returns (uint _balance){
        _balance = address(this).balance;
    }


    // 消息会携带value 所以需要标注为payable
    function setx(uint256 x) external payable {
        _x = x;
        if(msg.value > 0){
            emit log(msg.value, gasleft());
        } 
    }

    // 返回这个_x,私有参数可以通过方法进行访问但不能直接访问
    function get_x() public view returns(uint x){
        x = _x;
    }
}


contract Callcontract{
    function callsetx(address add,uint256 x) external {
        // 调用的这个合约的名称和地址都需要自己来找
        othercontract(add).setx(x);
    }

    function callgetx(address add) external view returns (uint256 x){
        othercontract c = othercontract(add);
        x = c.get_x();
    }

    function callgetx2(othercontract add) external view returns (uint256) {
        return add.get_x();
    }

    function setxtransfereth(address add,uint256 x) external payable{
        // 这种payable方法可以通过这种方式为消息携带币种
        // msg.value是调用方携带的币种数量
        othercontract(add).setx{value:msg.value}(x);
    }
}

可以通过这种方式去间接调用合约。

相关推荐
Richown1 小时前
Git工作流:GitFlow与GitHub Flow最佳实践
区块链·react
Richown2 小时前
智能合约测试:使用Foundry进行形式化验证
区块链·react
Richown3 小时前
前端安全:XSS、CSRF攻击与防御
区块链·react
Richown4 小时前
CI/CD流水线:使用GitHub Actions自动化部署
区块链·react
Richown4 小时前
前端工程化:Vite与Rollup构建优化
区块链·react
Richown4 小时前
数据分析:Pandas与数据清洗实战
区块链·react
Richown4 小时前
Web3钱包开发:使用Ethers.js集成MetaMask
区块链·react
Richown5 小时前
机器学习入门:TensorFlow.js实战
区块链·react
mutourend19 小时前
Zcash 与量子计算机
区块链·量子计算·后量子密码学
TechubNews20 小时前
稳定币下一战:不是谁发币,而是谁掌握结算通道
人工智能·web3·区块链