【solidity 学习】错误处理机制汇总

最近发现了一个很好的学习 web3 知识的平台 hackquest,也是一个社区,不仅可以学习 web3 知识,并且经常组织一些线上线下的活动鼓励大家稳步学习。

hackquest 网址

最近我在 solidity ,其中关于错误处理机制有三种:revert、require、assert、error、try\catch。他们的用法类似,容易产生混淆,这里记录一下他们的使用场景以及区别,以便容易区分:

使用场景

  • require() 用法
    1.验证用户输入,例如:require(input < 20);
    2.验证外部合约的调用,例如:require(external.send(amount));
    3.在执行之前验证状态条件,例如:require(balance[msg.sender] >= amount)
  • revert() 用法
    1.处理与require()类似但逻辑更复杂的情况
    2.当存在复杂的嵌套if/else逻辑流时,可以使用revert()代替require()
    3.请注意,复杂的逻辑可能是代码质量不佳的一个迹象,所以在开发中请尽量避免使用revert。
  • assert() 用法
    1.检查溢出/下溢,例如:c = a + b; assert(c > b);
    2.检查不变量,例如:assert(this.balance >= totalSupply);
    3.在更改后验证状态
    4.防止永远不可能发生的情况
  • try/catch
    使用try-catch语句来处理可能存在的错误。并且可以使用catch (error err)语句来捕获特定的错误类型:

区别

assert 的作用和 revert 没有区别,但在 gas 的消耗上有较大的差异:

  1. assert:使用 assert 时,它会消耗掉调用者所发送的剩余未使用的 gas 。你可以将其看作一个恶霸,它不仅阻止你的前进,还会夺走你身上携带的所有现金。
  2. revert和 require:与 assert 不同,revert 和 require 更像是施工队。它们只会阻止你前进,但不会抢走你的财物。当使用 revert 或 require 时,Solidity 会将未使用的 gas 退还给调用者。
相关推荐
声网27 分钟前
OpenAI Realtime API 重磅更新:锚定语音模型「深度推理+自主执行」演进路径|Voice Agent 学习笔记
笔记·学习
前端摸鱼匠40 分钟前
【AI大模型春招面试题31】什么是“零样本学习(Zero-Shot)”“少样本学习(Few-Shot)”?大模型实现这类能力的核心原因?
人工智能·学习·面试·大模型·求职招聘
薛定猫AI2 小时前
【深度解析】Hermes Agent:持久记忆、自学习闭环与桌面化 Autonomous AI 工作流实践
人工智能·学习
老虎06272 小时前
黑马程序员苍穹外卖--学习笔记(苍穹外卖万字总结—重点知识,面试常见问题)超全
笔记·学习·面试
sealaugh322 小时前
react native(学习笔记第四课) 英语打卡微应用(3)-ocr的文字转化成语音文件(tts)
笔记·学习·react native
小新同学^O^2 小时前
简单学习 --> SpringAOP
java·学习·spring·aop
炽烈小老头3 小时前
【每天学习一点算法 2026/05/10】合并K个排序链表
学习·算法·链表
wuxinyan1233 小时前
大模型学习之路010:RAG 零基础入门教程(第六篇):重排序技术
人工智能·学习·rag
xian_wwq3 小时前
【学习笔记】大模型微调实战指南
笔记·学习·微调·llama factory
晓梦林3 小时前
Qingmei靶场学习笔记
笔记·学习·安全·web安全