// 拿到模版合约的创建字节码(理解为合约ABI文件不知道有没有问题)
type(合约文件名).creationCode returns (bytes)
// 拿到模版合约的运行字节码(理解为合约ABI文件不知道有没有问题)
type(合约文件名).runTimeCode returns (bytes)
// 计算参数的ABI编码。
abi.encode(...) returns (bytes);
// 计算参数的紧密打包编码
abi.encodePacked(...) returns (bytes);
// 计算函数选择器和参数的ABI编码
abi. encodeWithSelector(bytes4 selector, ...) returns (bytes);
// 等价于 abi.encodeWithSelector
abi.encodeWithSignature(string signature, ...) returns (bytes);
// 对给定第二个开始的参数进行编码,并以给定的函数选择器作为起始的 4 字节数据一起返回
abi.encodeWithSelector(bytes4(keccak256(signature), .)
// 一种算法,返回bytes256
keccak256(...) returns (bytes32)
// 合约内部的汇编代码
create2(v, n, p, s)
例:create new contract with code mem[p..(p+s)) at address keccak256(<address> . n . keccak256(mem[p..(p+s))) and send v wei and return the new address
参数:v 发送到新合约地址的数量 n 代码的长度 p 代码的起始内存 s 使用keccak256编码后的到的salt
解释:使用代码 mem[p..(p+s)) 在地址 keccak256(<address> . n . keccak256(mem[p..(p+s))) 创建新合约并发送 v wei 并返回新地址
// 获取消息的签名地址,使用签名消息与v,r,s作为参数
ecrecover(bytes32 hash, uint8 v, bytes32 r, bytes32 s) returns (address)
// 合约执行者
msg.sender
// 产生交易时携带的eth数量
msg.value
// 合约地址
address(this)
// 空地址
address(0)
solidity一些基本语法
最新推荐文章于 2024-08-15 14:50:31 发布