当前位置:首页 > 工控原理 > 正文

如何防止算术运算出现下溢和溢出错误

来源:网络  发布者:电工基础  发布时间:2026-03-05 07:48
整数溢出和下溢 与C和C ++一样,Solidity是一种比较低级别的编码语言,没有处理存储限制的功能。这可能与Ruby和Python开发人员习惯的非常不同。

整数溢出和下溢

与C和C ++一样,Solidity是一种比较低级别的编码语言,没有处理存储限制的功能。这可能与Ruby和Python开发人员习惯的非常不同。

以太坊的智能合约存储分别为256位或32字节。 Solidity支持有符号整数和无符号整数uint,最高可达256位。

这意味着当您的数字超过在分配的存储位之下或之上时,您的算术运算容易出现下溢和溢出错误。

注意:最大可能的uint256等于115792089237316195423570985008687907853269984665640564039457584007913129639935

contract Unsigned {

uint8 public min = 0;

uint8 public max = 255;

// Underflowing & overflowing doesn‘t throw an error

uint8 public less_than_min = min - 1; // returns 255

uint8 public more_than_max = max + 1; // returns 0

}

contract Signed {

int8 public min = -128;

int8 public max = 127;

int8 public less_than_min = min - 1; // returns 127

int8 public more_than_max = max +1; // returns -128

}

以下是上面代码段的可视化:

这会使得处理算术运算符的合约易受攻击。通常我们从safemath.sol库继承数学运算符。

细节演练

1. 注意Telephone.sol的changeOwner函数检查是否(tx.origin!= msg.sender)。似乎我们可以通过方案3成功触发此功能:区块链研究实验室| 如何防止滥用智能合约中的伪随机性

2. 创建一个电话合约,Telephony构成合同A.在Telephony中实例化合约B,您的Telephone.sol:

contract Telephony {

Telephone public phone = Telephone(YOUR_INSTANCE_ADDR_HERE);

//TODO.。.

}

3、在Telephony中创建一个changeOwner函数,该函数调用Telephone中的changeOwner函数,即玩电话游戏。

function changeOwner(address _owner) public {

phone.changeOwner(_owner);

}

4、注意await contract.owner()在控制台中现在指示您的用户钱包是所有者!

相关热词:#区块链

最新文章
连续脉冲发生器电路图连续脉冲发生器电路图

时间:2026-03-05

正弦波发生器原理图正弦波发生器原理图

时间:2026-03-05

话筒用单音猝发电路话筒用单音猝发电路

时间:2026-03-05

静噪电路图静噪电路图

时间:2026-03-05

开路转播机的引入控制电路开路转播机的引入控制电路

时间:2026-03-05

控制单音发生器电路控制单音发生器电路

时间:2026-03-05

六路单管电路图六路单管电路图

时间:2026-03-05

选取单音波群电路选取单音波群电路

时间:2026-03-05

选取单音发生器电路选取单音发生器电路

时间:2026-03-05

亚声频单音编码器电路亚声频单音编码器电路

时间:2026-03-05