继承
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优先。