solidity实战

合约间转账

用到address类型的transfer方法

在这里插入图片描述

  • 话不多说,先上代码
// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.6.2 <0.9.0;

contract InfoFeed {
    function info() public payable returns (uint256 ret) {
        return 42;
    }

    function getBalance() public view returns (uint) {
        return address(this).balance;
    }
}

contract Consumer {
    fallback() external payable {}
    receive() external payable {}

    InfoFeed feed;

    function setFeed(InfoFeed addr) public {
        feed = addr;
    }

    function callFeed() public {
        feed.info{value: 10, gas: 800}();
    }

    function transferToContract() payable public {
        payable(address(this)).transfer(msg.value);
    }

    function getBalance() public view returns (uint) {
        return address(this).balance;
    }
}

  • 使用方法
    1、先部署两个合约
    在这里插入图片描述
    2、先选择要给Consumer合约转多少钱,这里以100Gwei为例;然后执行transferToContract方法:
    在这里插入图片描述

这样,Cosumer合约就有了100 * 10^9 wei的以太:
在这里插入图片描述
3、再执行setFeed方法,参数传入InfoFeed的合约地址;接着调用callFeed函数,作用是从Consumer合约给InfoFeed合约转账10wei,这时再获取Consumer合约的balance,就显示被扣除了10wei:
在这里插入图片描述
相应的,InfoFeed合约的balance已经多了10wei:
在这里插入图片描述

合约的继承

// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.7.0 <0.9.0;
// pragma solidity ^0.5.17;

contract A {
    uint public x;
    function setValue(uint _x) public {
        x = _x;
    }
}

contract B {
    uint public y;
    function setValue(uint _y) public {
        y = _y;
    }
}

contract C is A, B {
}

在0.5版本之前,对于相同方法名和参数的方法默认是最远继承原则,即C合约的setValue方法继承自最远的B。
0.5版本后,上述代码编译会报错:Derived contract must override function "setValue". Two or more base classes define function with same name and parameter types.

意思是:父合约定义具有相同名称和参数类型的函数,派生合约必须重写(override)函数setValue。

重写必须在 override 修饰符中列出父合约。override(A, B)中的顺序无关紧要,它不会改变super的行为,继承关系由 contract C is A, B { ... }声明的顺序决定。

// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.7.0 <0.9.0;

contract A {
    uint public x;
    function setValue(uint _x) public virtual {
        x = _x;
    }
}

contract B {
    uint public y;
    function setValue(uint _y) public virtual {
        y = _y;
    }
}

contract C is A, B {
    function setValue(uint _z) public override(A, B) {
        A.setValue(_z);
        B.setValue(_z + 1);
    }
}

Tips:有 overridevritual 两个关键字标记符;

此时合约C有两个成员变量xy和一个成员方法setValue,执行setValue将会把_z赋值给C.x,把_z + 1赋值给C.y
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值