市值: $2.17T 0.51%
成交额(24h): $84.1809B 12.71%
恐惧与贪婪指数:

15 - 极度恐惧

  • 市值: $2.17T 0.51%
  • 成交额(24h): $84.1809B 12.71%
  • 恐惧与贪婪指数:
  • 市值: $2.17T 0.51%
加密货币
话题
百科
资讯
加密话题
视频
热门加密百科

选择语种

选择语种

选择货币

加密货币
话题
百科
资讯
加密话题
视频

什么是整数溢出和下溢漏洞以及 SafeMath 如何预防它们?

Integer overflow and underflow in smart contracts can lead to critical vulnerabilities, enabling attackers to manipulate balances and disrupt decentralized economies.

2025/11/14 09:59

了解智能合约中的整数溢出和下溢

1. 在区块链开发中,特别是在用 Solidity 编写的以太坊智能合约中,算术运算直接对无符号整数执行。当计算超过数据类型可以容纳的最大值时,就会发生整数溢出。例如,如果 uint8 变量保存 255 并且加 1,它会回绕到 0,而不是变成 256。

2. 相反,当减法运算的结果低于最小可表示值时,就会发生整数下溢。如果 uint8 变量包含 0 并减 1,它将回绕到 255。这些行为源于以太坊虚拟机 (EVM) 中低级算术的工作方式,该虚拟机不会自动检查此类边界违规。

3.此类漏洞可能被恶意利用。攻击者可能会操纵代币余额、夸大所有权或触发意外的逻辑流。 BeautyChain 代币发生了一个著名的案例,溢出使攻击者能够生成大量代币,从而破坏经济稳定。

4. 这些缺陷通常潜伏在代码中,直到被特定输入触发。由于它们在正常 EVM 执行下不会产生运行时错误,因此它们在基本测试期间保持不可见。它们的存在破坏了去中心化应用程序中金融运营的完整性。

5. 影响不仅限于个人合同。基于溢出或下溢的漏洞可能会削弱用户信任,导致资金损失,并损害基于受影响协议构建的整个平台的声誉。

SafeMath 库在降低风险方面的作用

1. 为了解决这些风险,引入了 SafeMath 库作为防御性编程工具。它提供了加法、减法、乘法和除法的包装函数,其中包括在执行任何操作之前的显式检查。

2. 使用 SafeMath.add(a, b) 时,该函数首先验证总和不会超过给定类型的最大值。如果结果溢出,事务将通过 require 语句恢复,从而阻止执行。

3. 同样,SafeMath.sub(a, b) 在减法之前确保 a 大于或等于 b。如果不是,操作将恢复,从而阻止可能破坏余额跟踪或访问控制机制的潜在下溢情况。

4. SafeMath.mul(a, b) 检查大数相乘时出现的溢出情况。即使两个操作数单独看起来都是安全的,它们的乘积也可能会超出存储限制,特别是在基于乘法器铸造代币等扩展操作中。

5. 通过恢复条件强制算术安全,SafeMath 有效地消除了整个类别的漏洞利用。在几次引人注目的黑客攻击强调了金融逻辑中输入验证的必要性之后,它的采用变得广泛。

算术保障措施的整合与演变

1. 开发人员通过导入库并使用“using”指令将其附加到 uint 类型来集成 SafeMath。应用后,标准操作员将在整个合同范围内自动替换为已检查的对应操作员。

2. 虽然 SafeMath 增加的 Gas 开销最小,但其安全效益远远超过成本。每次检查都会消耗额外的计算量,但这种投资可以防止可能导致不可逆转的资产损失的灾难性故障。

3. 现代版本的 Solidity(从 0.8.0 开始)已将上溢和下溢检查原生集成到语言中。这意味着算术运算现在默认恢复,无需外部库,从而减少了对较新代码库中 SafeMath 的依赖。

4. 尽管有本机支持,但由于向后兼容性要求,许多遗留系统仍然依赖 SafeMath。作为漏洞评估的一部分,审计员会定期检查旧合同是否缺少 SafeMath 的使用。

5. 向更安全的违约的过渡反映了更广泛的行业学习。曾经需要手动干预的内容现在已嵌入到编译器行为中,说明了现实世界中的漏洞如何推动语言设计和开发人员工具的改进。

正确使用算术保护措施可以防止对余额和津贴等关键值进行未经授权的操纵,从而保护去中心化应用程序的经济模型。

常见问题解答

当 SafeMath 检查失败时会发生什么?当 SafeMath 操作检测到不安全的算术条件时,它会触发恢复。这将取消事务并将状态恢复到执行开始之前的状态,确保不会永久记录任何更改。

有符号整数也会发生溢出吗?是的,有符号整数也容易受到攻击。根据操作,它们可以溢出到负范围或下溢到正范围。尽管在余额跟踪中不太常见,但它们在控制逻辑和索引方面带来了类似的风险。

Solidity 0.8+ 中还需要 SafeMath 吗?在大多数情况下,不会。 Solidity 0.8 及更高版本包含针对所有算术运算的内置溢出和下溢保护。但是,为了明确清晰度或在使用未经检查的块时,开发人员仍然可以使用 SafeMath。

SafeMath 是否存在性能成本?每个 SafeMath 函数都包含条件检查,与原始算术相比,这些条件检查会消耗额外的 Gas。虽然每次操作的增量很小,但它可能会在涉及循环或频繁更新的复杂计算中累积。

免责声明:info@kdj.com

所提供的信息并非交易建议。根据本文提供的信息进行的任何投资,kdj.com不承担任何责任。加密货币具有高波动性,强烈建议您深入研究后,谨慎投资!

如您认为本网站上使用的内容侵犯了您的版权,请立即联系我们(info@kdj.com),我们将及时删除。

相关百科

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

2026-06-06 02:54:55

合同结算机制1. Bybit的线性永续合约以USDT结算,这意味着所有盈亏计算、保证金要求和清算门槛均以稳定币单位计价。 2.反向永续合约以BTC本身结算,因此每笔交易都会直接影响交易者的BTC余额——收益会增加BTC持有量,而损失会减少BTC持有量。 3. 反向合约的定价引擎使用 BTC/USDT...

如何识别和避免止损、欺骗等期货市场操纵行为?

如何识别和避免止损、欺骗等期货市场操纵行为?

2026-06-07 14:20:10

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

2026-06-04 16:40:15

账户级损失限额配置1. 使用双因素身份验证通过网络或移动应用程序登录您的 Bybit 帐户。 2. 导航至“资产”部分,然后从左侧菜单中选择“风险管理”。 3. 选择“每日损失限制”并将该功能切换为“开”以激活控制。 4. 输入代表当前交易日 USDT 最大允许净亏损的数值。 5. 使用您的电子邮件...

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

2026-06-05 04:59:43

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少每个区块新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将使其达到 3.1...

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

2026-06-04 03:59:47

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何处理美国加密货币期货交易利润的税务影响?

如何处理美国加密货币期货交易利润的税务影响?

2026-05-29 18:19:59

Bitcoin 减半机制1. Bitcoin 的协议强制规定 2100 万枚代币的固定供应上限,并通过区块奖励引入新单位。 2. 每 210,000 个区块(大约每四年)区块奖励就会减少一半,这个过程称为减半。 3. 最近一次减半发生在 2024 年 4 月,每个区块的奖励从 6.25 BTC 减少...

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

2026-06-06 02:54:55

合同结算机制1. Bybit的线性永续合约以USDT结算,这意味着所有盈亏计算、保证金要求和清算门槛均以稳定币单位计价。 2.反向永续合约以BTC本身结算,因此每笔交易都会直接影响交易者的BTC余额——收益会增加BTC持有量,而损失会减少BTC持有量。 3. 反向合约的定价引擎使用 BTC/USDT...

如何识别和避免止损、欺骗等期货市场操纵行为?

如何识别和避免止损、欺骗等期货市场操纵行为?

2026-06-07 14:20:10

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

2026-06-04 16:40:15

账户级损失限额配置1. 使用双因素身份验证通过网络或移动应用程序登录您的 Bybit 帐户。 2. 导航至“资产”部分,然后从左侧菜单中选择“风险管理”。 3. 选择“每日损失限制”并将该功能切换为“开”以激活控制。 4. 输入代表当前交易日 USDT 最大允许净亏损的数值。 5. 使用您的电子邮件...

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

2026-06-05 04:59:43

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少每个区块新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将使其达到 3.1...

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

2026-06-04 03:59:47

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何处理美国加密货币期货交易利润的税务影响?

如何处理美国加密货币期货交易利润的税务影响?

2026-05-29 18:19:59

Bitcoin 减半机制1. Bitcoin 的协议强制规定 2100 万枚代币的固定供应上限,并通过区块奖励引入新单位。 2. 每 210,000 个区块(大约每四年)区块奖励就会减少一半,这个过程称为减半。 3. 最近一次减半发生在 2024 年 4 月,每个区块的奖励从 6.25 BTC 减少...

查看所有文章

User not found or password invalid

Your input is correct