Skip to content

Latest commit

 

History

History
156 lines (125 loc) · 8.29 KB

awaqawaqawaq.md

File metadata and controls

156 lines (125 loc) · 8.29 KB

timezone: Asia/Shanghai

awaqawaqawaq

  1. 区块链新人,没有经验,啥也不会,不过总有开始的一步(

  2. 你认为你会完成本次残酷学习吗? maybe(70%)

Notes

2024.09.23

时间:45min 學習內容: solidity101 1~5

  • Solidity 是一种用于编写以太坊虚拟机(EVM)智能合约的编程语言。

  • 值类型(Value Type)/引用类型(Reference Type)/映射类型(Mapping Type)

  • 函数格式

function <function name>(<parameter types>) {internal|external|public|private} [pure|view|payable] [returns (<return types>)]
  • 注意:Pure函数是不修改状态,纯计算函数

  • internal external payable

  • 返回值:return 和 returns returns () 是函数的返回值声明,用于指定函数的返回类型。它必须紧跟在函数名和参数列表之后,并且用圆括号括起来。

    function returnNamed2() public pure returns(uint256 _number, bool _bool, uint256[3] memory _array)

    returns 中标明返回变量的名称。Solidity 会初始化这些变量,并且自动返回这些函数的值,无需使用 return。

  • storage,memory和calldata

storage(合约的状态变量)赋值给本地storage(函数里的),memory赋值给memory,会创建引用

  • tansfer的默认单位是wei

2024.09.24

时间:90min 學習內容: solidity101 5~10

  • array:

    • bytes比较特殊,是数组,但是不用加[]
    • memory动态数组,可以用new操作符来创建,但是必须声明长度
    • 如果创建的是动态数组,你需要一个一个元素的赋值
  • struct

  • Mapping,struct和array不可以作为mapping的key

  • 变量初始值

  • 0x00 = 1 byte

  • constant和immutable -string可以是constant,但是不能是immutable,constant的值在编译时确定,immutable的值在部署时确定

  • 定义时赋值为显示赋值,构造函数为隐式赋值

2024.09.25

时间:90min 學習內容: solidity101 11~15

  • 构造函数
  • modifier 类似decorator
  • event
    • Solidity中的事件(event)是EVM上日志的抽象,它具有两个特点:

      响应:应用程序(ethers.js)可以通过RPC接口订阅和监听这些事件,并在前端做响应。

      经济:事件是EVM上比较经济的存储数据的方式,每个大概消耗2,000 gas;相比之下,链上存储一个新变量至少需要20,000 gas。

    • event (); // 声明事件

    • emit (); // 触发事件

    • indexed 记的参数可以理解为检索事件的索引“键”

  • require和revert
    • error 可自定义,可包含信息,revert error() gas最低
    • require(condition, "error message"); // 如果条件为false,则回滚交易并返回错误信息
    • revert("error message"); // 回滚交易并返回错误信息
  • assert
    • assert(condition); // 如果条件为false,则回滚交易并返回错误信息,并且不会返回任何错误信息
  • 继承
    • virtual 和 override
    • 钻石继承(菱形继承)使用super会调用继承链条上的每一个合约的相关函数
  • 抽象合约 接口
    • 接口与合约ABI(Application Binary Interface)等价,可以相互转换,通过 IERC721 IERC721等可以调用实现接口功能的合约
    • 接口不能包含状态变量,只能包含函数声明
    • 接口不能包含构造函数,也不能包含函数体
    • 接口不能继承其他合约,只能继承其他接口

2024.09.26

时间:90min 學習內容: solidity102 16~20

  • overloading 重载

  • 库合约

    • using A for B;语法糖 B.xxx()调用A函数

    • A.xxx()

    • Strings:将uint256转换为String

      Address:判断某个地址是否为合约地址

      Create2:更安全的使用Create2 EVM opcode

      Arrays:跟数组相关的库合约

  • import

  • receive 和 fallback

  • 接收ETH调用 receive,fallback()函数会在调用合约不存在的函数时被触发。可用于接收ETH,也可以用于代理合约proxy contract。一般external payable修饰

  • transfer send call

  • tansfer和send的区别在于,如果接收者合约没有receive函数,那么transfer会回滚交易,而send会返回一个布尔值,表示交易是否成功。

  • call和send的区别在于,call可以调用合约的任何函数,而send只能发送ETH。call可以返回一个布尔值,表示交易是否成功,也可以返回一个字节数组,表示函数的返回值。

  • (bool success,) = _to.call{value: amount}(""); // 使用call发送ETH, ("")为msg,如果receive()无法处理,就会调用fallback()

2024.09.27

  • _Name(_Address).f(),其中f()是要调用的函数。
  • 如果能直接调用原合约的set() 是不安全的
  • call
    • 目标合约地址.call(字节码); abi.encodeWithSignature("函数签名", 逗号分隔的具体参数)
    • 返回 (bool, bytes memory) 需要通过abi.decode解码
    • 失败会调用 fallback()函数
  • Delegatecall
    • 而当用户A通过合约B来delegatecall合约C的时候,执行的是合约C的函数,但是上下文仍是合约B的:msg.sender是A的地址,并且如果函数改变一些状态变量,产生的效果会作用于合约B的变量上。

2024.09.29

  • create & create2

    • Contract x = new Contract{value: _value}(params)
      • Contract是要创建的合约名,x是合约对象(地址),如果构造函数是payable,可以创建时转入_value数量的ETH,params是新合约构造函数的参数。
      • 新地址 = hash(创建者地址, nonce)
  • create2 - CREATE2的目的是为了让合约地址独立于未来的事件。不管未来区块链上发生了什么,你都可以把合约部署在事先计算好的地址上。用CREATE2创建的合约地址由4个部分决定:

      0xFF:一个常数,避免和CREATE冲突
      CreatorAddress: 调用 CREATE2 的当前合约(创建合约)地址。
      salt(盐):一个创建者指定的bytes32类型的值,它的主要目的是用来影响新创建的合约的地址。
      initcode: 新合约的初始字节码(合约的Creation Code和构造函数的参数)。
    
    • 新地址 = hash("0xFF",创建者地址, salt, initcode)
    • Contract x = new Contract{salt: _salt, value: _value}(params)

2024.09.30

  • selfdestruct

    • selfdestruct命令可以用来删除智能合约,并将该合约剩余ETH转到指定地址。
    • 在以太坊坎昆(Cancun)升级中,EIP-6780被纳入升级以实现对Verkle Tree更好的支持。EIP-6780减少了SELFDESTRUCT操作码的功能。 已经部署的合约无法被SELFDESTRUCT了。 如果要使用原先的SELFDESTRUCT功能,必须在同一笔交易中创建并SELFDESTRUCT。
    • selfdestruct(payable(msg.sender));
    • 使用selfdestruct()函数删除合约时,合约中的所有状态变量都会被删除,但合约中的函数仍然可以访问这些状态变量。因此,在删除合约之前,应该确保所有状态变量都被正确地处理。
    • 对外提供合约销毁接口时,最好设置为只有合约所有者可以调用,可以使用函数修饰符onlyOwner进行函数声明。 当合约中有selfdestruct功能时常常会带来安全问题和信任问题,合约中的selfdestruct功能会为攻击者打开攻击向量(例如使用selfdestruct向一个合约频繁转入token进行攻击,这将大大节省了GAS的费用,虽然很少人这么做),此外,此功能还会降低用户对合约的信心。
  • ABI编码

    • ABI(Application Binary Interface)是以太坊和其他区块链平台中用于定义智能合约与外部应用程序(如前端、其他合约)之间交互的规范。
    • abi.encode,
    • abi.encodePacked, //压缩数据,无法正常吉奥胡
    • abi.encodeWithSignature,
    • abi.encodeWithSelector
    • abi.encodeWithSelector(bytes4(0x533ba33a));通过abi函数选择器,address(contract).staticcall(data)来调用相关函数
  • Hash

    • 生成数据唯一标识
    • Solidity使用keccak256,返回一个32字节的哈希值。