Soildity语言为了方便开发人员进行合约代码的编写,在语言设计时内置了一些单位,变量和函数,下面将为大家一一介绍。
1. 内置单位
1.1 货币单位
一个字面量的数字可以使用 wei、finney、szabo、ether等后缀表示不同的额度,其换算关系如下:
1 ether == 10^3 finney
1 ether == 10^6 szabo
1 ether == 10^18 wei
1.2 时间单位
1 == 1 seconds (默认单位)
1 minutes == 60 seconds
1 hours == 60 minutes
1 days == 24 hours
1 weeks = 7 days
1 years = 365 days
2. 全局变量
this:只当前的合约,可以转换为地址类型
block.conisbase:类型为address,表示当前区块的矿工的帐号地址
block.difficulty:类型为uint,表示当前区块的挖矿难度
block.gaslimit:类型为uint,表示当前区块的Gas限制
block.number:类型为uint,表示当前的区块编号
block.timestamp:类型为uint,以UNIX时间戳的形式表示当前区块的产生时间
msg.data:类型为bytes,表示完整的调用数据
msg.gas:类型为uint,表示剩余的Gas
msg.sender:类型为address,表示当前消息的发送者地址
msg.sig:类型为bytes4,调用数据的前4字节,函数标识符
msg.value:类型为uint,表示该消息转账的以太币数额,单位为wei
now:类型为uint,表示当前时间
tx.gasprice:类型为uint,表示当前交易的Gas价格
tx.origin:类型为address,表示完整调用链的发起者
3. 内置函数
3.1 区块函数
block.blockhash(uint blockNumber) returns (bytes32):获取指定区块的散列值,只对不包括当前区块的256个最近的区块有效
3.2 异常处理函数
assert(bool condition):当条件不为真时抛出异常,用于处理内部错误
require(bool condition):当条件不为真时抛出异常,用于处理输入或者来自外部模块的错误
revert():中断程序执行并且回退状态改变
3.3 数学和加密算法函数
addmod(uint x,uint y,uint k) returns (uint):计算(x+y)%k
mulmod(uint x,uint y,uint k) returns (uint):计算(x*y)%k
keccak256(...) returns(bytes32):计算Ethereum-SHA3(Keccak-256)散列值
sha3(...) returns (bytes32):keccak256()方法的别名
sha256(...) returns (bytes32):计算SHA-256散列值
ripemd1606(...) returns (bytes20):计算RIPEMD160散列值
ecrecover(bytes32 hash,uint8 v,bytes32 r,bytes32 s) returns(address):根据公钥,使用ECDSA算法对地址进行解密,返回地址
3.4 合约函数
selfestruct(address recipient):销毁当前合约,并且将全部的以太币余额转账到作为参数传入的地址
suicide(address recipient):selfestruct函数的别名
以上是本人目前总结到的Soildity所有内置的一些变量和函数,后续有更新将补充!