整型(Integer)
优质
小牛编辑
137浏览
2023-12-01
int/uint
:变长的有符号或无符号整型。变量支持的步长以8
递增,支持从uint8
到uint256
,以及int8
到int256
。需要注意的是,uint
和int
默认代表的是uint256
和int256
。
支持的运算符:
比较:
<=
,<
,==
,!=
,>=
,>
,返回值为bool
类型。位运算符:
&
,|
,(^
异或),(~
非)。数学运算:
+
,-
,一元运算+
,*
,/
,(%
求余),(**
平方)。
整数除法总是截断的,但如果运算符是字面量,则不会截断(后面会进一步提到)。另外除0
会抛异常 ,我们来看看下面的这个例子:
pragma solidity ^0.4.0;
// simple store example
contract simpleStorage{
uint valueStore; //
function add(uint x, uint y) returns (uint z){
z = x + y;
}
function divide() returns (uint z){
uint x = 1;
uint y = 2;
z = x / y;
}
}
整数字面量
整数字面量,由包含0-9的数字序列组成,默认被解释成十进制。在Solidity
中不支持八进制,前导0
会被默认忽略,如0100
,会被认为是100
。
小数由.
组成,在他的左边或右边至少要包含一个数字。如1.
,.1
,1.3
均是有效的小数。
字面量本身支持任意精度,也就是可以不会运算溢出,或除法截断。但当它被转换成对应的非字面量类型,如整数或小数。或者将他们与非字面量进行运算,则不能保证精度了。
pragma solidity ^0.4.0;
contract IntegerLiteral{
function integerTest() returns (uint, uint){
//超出运算字长了
var i = (2**800 + 1) - 2**800;
var j = 1/3*3;
//小数运算
var k = 0.5*8;
return (i, j);
}
}
总之来说就是,字面量怎么都计算都行,但一旦转为对应的变量后,再计算就不保证精度啦。