继承

Solidity通过复制包括多态的代码来支持多重继承。所有函数调用是虚拟(virtual)的,这意味着最远的派生方式会被调用,除非明确指定了合约。当一个合约从多个其它合约那里继承,在区块链上仅会创建一个合约,在父合约里的代码会复制来形成继承合约。

solidity的继承链是靠右的更近,这点和python不一样

is关键字

pragma solidity ^0.4.11;

contract A {
    uint public a;

    function A(uint _a) internal {
        a = _a;
    }
}

contract B is A(1) {
    function B() public {}
}

如代码所示:B合约继承了A合约。

  • 如果把构造函数设置为internal的话,会把合约标记为抽象。
  • 构造函数 可以是 public 或 internal。

子类需要提供基础构造函数所需的所有参数。 这可以通过两种方式完成:

pragma solidity ^0.4.0;

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

contract Derived is Base(7) {
    function Derived(uint _y) Base(_y * _y) public {
    }
}

一种方法是直接在继承列表中(是Base(7))。 另一种方式是在派生构造函数的头部(Base(_y * _y))中调用modifier。

  • 第一种方法适用于构造函数参数是个常量。
  • 第二种方法适用于构造函数参数取决于父类构造参数。
  • 如果像上面代码一样两个都用了,modifier优先。

results matching ""

    No results matching ""