智能合约漏洞——int 溢出校验

本文探讨了在Solidity智能合约中,为何不能仅依赖`pure`函数的范围检查来防止整数溢出,通过实例展示了使用`require`进行溢出检查的重要性。重点介绍了如何正确处理`int`类型溢出,以及主流的通过结果正负判断来避免回绕溢出的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 

function add(uint256 a, uint256 b) internal pure returns (uint256) { 
   
   uint256 c = a + b;
   require(c >= a); 
   return c;
 }

对于 int 类型的整数溢出不能用这个safemath去校验,目前主流的方法是判断结果是否大于0 ,小于0 证明回绕溢出了

var x int8 = 120;
var y int8 = 8;
var z = x + y;
println(z) // -128

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值