Solidity默认单位
货币单位
- wei
- finney
- szabo
- ether
若不加后缀,则默认都为wei
时间单位
- 1==1 seconds
- 1 minutes == 60 seconds
- ……
特别注意,使用这些单位时要特别小心,因为一年并不总有365天;同时因为有闰秒的存在,一天也并不总是24小时。
为了保证日历库的精确性,最好由外部供应商定期更新。
区块和交易属性
- block.blockhash(uint blockNumber) returns(bytes32):获取特定区块的散列值,只对不包括当前区块的256个最近的区块有效。
- block.coinbase:类型为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,表示当前时间,是block.timestamp的别名。
- tx.gasprice:类型为uint,表示当前交易Gas价格
- tx.origin:类型为address,表示完整调用链的发起者。
异常处理
- assert(bool condition):当条件不为真时,抛出异常,用于处理内部的错误
- require(bool condition):当条件不为真时,抛出异常,用来处理输入或者来自外部模块的错误
- revert():中断程序执行并回退状态改变
数学和加密函数
- addmod(uint x,uint y,uint k) returns(uint):计算(x+y)%k,加法支持任意精度,但不超过2的256次方
- mulmod(uint x,uint y,uint k) returns(uint):计算(x*y)%k,乘法支持任意精度,但不超过2的256次方
- keccak256(…) returns(bytes32):计算Ethereum-SHA-3散列值
- sha3(…) returns(bytes32):上面的别名,跟上面功能一样
- sha256(…) returns(bytes20):计算RIPEMD-160散列值
- ecrecover(bytes32 hash,uint8 v,bytes32 r,bytes32 s) – returns (address):根据公钥,使用ECDSA算法对地址进行解密,返回解密后的地址,如果发生错误,则返回0
与合约相关的变量和函数
- this:指代当前的合约,可以转换为地址类型
- selfdestruct(address recipient):销毁当前合约,并且将全部的以太币余额转账到该地址。
- suicide(address recipient):同上
原文:https://blog.csdn.net/dieju8330/article/details/82502042
关注公众号:程序新视界,一个让你软实力、硬技术同步提升的平台
除非注明,否则均为程序新视界原创文章,转载必须以链接形式标明本文链接
本文链接:https://choupangxia.com/2019/07/29/solidity%e9%bb%98%e8%ae%a4%e5%8d%95%e4%bd%8d/