Solidity继承的语法

假设你有一个基本合约 a,你想创建一个新的合约 b,它继承自 a。这可以通过使用is关键字实现。

继承例子

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract BaseContract {
  // 父合约的成员变量和方法
  string name = "hello";

  function getNane() external view   returns (string memory){
    return name;
  }
}

contract DerivedContract is BaseContract {  
  // 部署这个合约,则可以,调用BaseContract的方法

}

多重继承

当你使用多重继承时,需要列出所有父合约,使用 , 隔开。

父合约是按照它们被列出的顺序被继承的,这个顺序可以影响到函数解析以及父合约构造函数的调用顺序

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract A {
    uint256 count;

    function getCount() public view returns (uint256) {
        return count;
    }
}

contract B {
    uint256 value;

    function getValue() public view returns (uint256) {
        return value;
    }
}

contract Name is A, B {}

继承后, 带构造方法的类

当你继承一个包含构造函数的合约时,你需要确保所有父合约的构造函数都被正确地调用并初始化。

Solidity提供了几种方式来实现这一点:

1. 在继承列表中指定父合约构造函数的参数。

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract A {
    uint256 count;

    function getCount() public view returns (uint256) {
        return count;
    }

    constructor(uint256 _co) {
        count = _co;
    }
}

contract B {
    uint256 value;

    function getValue() public view returns (uint256) {
        return value;
    }

    constructor(uint256 _co) {
        value = _co;
    }
}

contract Name is A(100), B(200) {

}

2. 直接在子合约的构造函数,调用父合约的构造函数 - 外部传入方式

继承多合约例子 的构造方法, -外部传入

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract A {
    uint256 count;

    function getCount() public view returns (uint256) {
        return count;
    }

    constructor(uint256 _co) {
        count = _co;
    }
}

contract B {
    uint256 value;

    function getValue() public view returns (uint256) {
        return value;
    }

    constructor(uint256 _co) {
        value = _co;
    }
}

contract Name is A, B {
    constructor(uint256 _a, uint256 _b) A(_a) B(_b) {

    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Solidity是一种面向智能合约的编程语言,用于在以太坊平台上开发去中心化应用(DApp)。它的基本语法结构包括以下几个方面: 1. 声明:使用关键字`contract`来声明一个合约,类似于面向对象编程中的类。例如:`contract MyContract { ... }` 2. 状态变量:在合约中声明的变量称为状态变量,它们存储在以太坊区块链上。可以使用关键字`uint`、`bool`、`address`等来声明不同类型的变量。例如:`uint public myNumber;` 3. 函数:合约中的函数用于定义合约的行为。可以使用关键字`function`来声明函数,并指定函数的可见性(如`public`、`private`等)。例如:`function myFunction() public { ... }` 4. 事件:事件用于在合约中触发和记录特定的操作。可以使用关键字`event`来声明事件,并定义事件的参数。例如:`event MyEvent(address indexed _from, uint _value);` 5. 修饰器:修饰器用于修改函数的行为或者检查函数的前置条件。可以使用关键字`modifier`来声明修饰器,并在函数定义时使用修饰器。例如:`modifier onlyOwner() { ... }` 6. 构造函数:构造函数在合约创建时执行,并用于初始化合约的状态变量。构造函数与合约同名,并且没有返回类型。例如:`constructor() { ... }` 7. 继承Solidity支持合约之间的继承关系,可以使用关键字`is`来实现继承。例如:`contract MyContract is BaseContract { ... }` 8. 异常处理:Solidity提供了异常处理机制,可以使用关键字`try`和`catch`来捕获和处理异常。例如:`try { ... } catch { ... }` 以上是Solidity的基本语法结构,通过这些基本元素可以编写出功能丰富的智能合约。如果你还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值