solidity是一个面向对象的静态语言,很多语法与java等语言很像,都有继承,抽象、多态等概念,这里只重点记录Solidity中的特有的内容。ps:以下有什么说的不对的地方欢迎大家指正,共同进步!

合约(Contract)

​ 在solidity中,contract就是java等其它语言的对象的概念,称为合约,其中包含状态变量、方法、modifier方法、事件、异常、结构体、枚举。此外,也有抽象合约、库(libraries))、接口(interface)的对象,抽象合约和接口的使用和其它面向对象的语言完全一致。

​ 状态变量其实和java中的成员变量,如果为public方法,会默认为getter方法。

方法(Function)

​ 有构造函数:**constructor(uint){…}**和普通函数:function helper(uint x) public pure returns (uint) {},函数可以有多个返回值。一个合约只能由一个构造函数。其中函数的变量有有memory和storage两种类型。

  • storage的结构是在合约部署创建时,根据你的合约中状态变量的声明,就固定下来了,并且不能在将来的合约方法调用中改变这个结构。storage中的内容是可以通过交易来改变的。
  • memory关键字告诉solidity应当在该函数运行时为变量创建一块空间,使其大小和结构满足函数运行的需要。

​ memory就是值传递,storage就是引用传递,但是当我们的函数参数如果为storage类型时,函数的可见性必须为internal或者private

方法的可见性

​ 方法的可见性为四种,可以被定义为:external, public, internal和private。

  • external: 外部函数是合约接口的一部分,这意味着它们可以从其他合约调用。
  • public:公共函数是合约接口的一部分,可以通过内部调用或通过消息调用。
  • internal:这些函数和状态变量只能内部访问(即在当前合约或由它派生的合约),而不使用被外部合约访问。
  • private:私有函数和状态变量仅仅在定义该合约中可见, 在派生的合约中不可见。
方法的修饰符

​ 修饰符可用于以声明方式更改函数的行为

  • view:承诺该方法只读猪肝汤,不修改状态,但是不强制
  • pure:承诺该方法即不读取状态,也不会修改状态,编译器并没有强制执行pure方法不是从状态中读取的
  • payable:表示该合约可以接受eth
  • override:表示重写
  • virtual:允许在派生合约中更改函数或修饰符的行为
  • modifier修饰符:可以用来改变一个函数的行为。修改器是一种合约属性,可被继承,同时还可被派生的合约重写,也可以接受参数,也可以有多个modifier修饰符。(https://new.qq.com/rain/a/20220106a04xad00)

事件(Event)

​ 事件是以太坊EVM提供的一种日志基础设施。事件可以用来做操作记录,存储为日志。也可以用来实现一些交互功能,比如通知UI,返回函数调用结果等。emit关键字就是触发事件。

异常(Errors)

​ Solidity 使用状态恢复异常来处理错误。这样的异常会撤消对当前调用(及其所有子调用)中状态所做的所有更改,并向调用者标记错误。

  • assert(bool condition)
  • require(bool condition)、require(bool condition, string memory message)
  • revert()、revert(string memory message)
  • try/catch语句:使用 try/catch 语句捕获外部调用中的失败try关键字后面必须跟一个表示外部函数调用或合约创建的表达式 ( ) 。表达式内部的错误不会被捕获

​ 结构体和枚举都是和其他语言保持一致,不在过多描述。

类型(Types)

​ Solidity中类型有:

  • bool:布尔类型
  • byte:bytes0 ~ bytes32
  • int/uint:整数,int可以表示负数,有int8,int16等,int和uint就是int256和uint256
  • address
  • 数组:和golang中的数组很像
  • string
  • mapping类型:就是哈希表。无法枚举所有的键值

地址类型(address)

​ 地址类型有多个内置方法,有

  • balance:该地址的余额
  • transfer:合约向该地址转账多少钱
  • send:合约向该地址转账多少钱,单位默认是wei

语法的内置特性

  • bytes.concat(...) returns (bytes memory):将可变数量的参数连接到一个字节数组
  • string.concat(...) returns (string memory):将可变数量的参数连接到一个字符串数组
  • block.basefee( uint):当前区块的基本费用
  • block.chainid( uint): 当前链 id
  • block.coinbase( ): 当前区块矿工地址``
  • block.difficulty( uint): 当前区块难度
  • block.gaslimit( uint): 当前区块gas限制
  • block.number( uint): 当前区块号
  • block.timestamp( uint): 自 Unix 纪元以来的当前区块时间戳(以秒为单位)
  • gasleft() returns (uint256): 剩余气体
  • msg.data( bytes): 完整的通话数据
  • msg.sender( address): 当前消息的发送者
  • msg.sig( bytes4):calldata 的前四个字节(即函数标识符)
  • msg.value( uint): 随消息发送的 wei 数量
  • tx.gasprice( uint): 交易的gas价格
  • tx.origin( address): 交易的发送者(完整的调用链)
  • blockhash(uint blockNumber) returns (bytes32): 给定区块的哈希 - 仅适用于 256 个最近的区块
  • keccak256(bytes memory) returns (bytes32): 计算输入的 Keccak-256 哈希
  • sha256(bytes memory) returns (bytes32): 计算输入的 SHA-256 哈希
  • ripemd160(bytes memory) returns (bytes20): 计算输入的 RIPEMD-160 散列
  • ecrecover(bytes32 hash, uint8 v, bytes32 r, bytes32 s) returns (address):从椭圆曲线签名中恢复与公钥关联的地址,错误返回零
  • this(当前合约的类型):当前合约
  • super: 继承层次中更高一级的合约
  • selfdestruct(address payable recipient):销毁当前合约,将其资金发送到给定地址,只有所有者才能销毁
  • type(C).name( string): 合约名称
  • type(C).creationCode( ):给定合约的创建字节码
  • type(C).runtimeCode( ):给定合约的运行时字节码
  • type(I).interfaceId( bytes4):包含给定接口的 EIP-165 接口标识符的值
  • type(T).min( T):整数类型可表示的最小值T
  • type(T).max( T):整数类型可表示的最大值T

Logo

为所有Web3兴趣爱好者提供学习成长、分享交流、生态实践、资源工具等服务,作为Anome Land原住民可不断优先享受各种福利,共同打造全球最大的Web3 UGC游戏平台。

更多推荐