合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
# 整型(Integer) `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); } } ``` 总之来说就是,字面量怎么都计算都行,但一旦转为对应的变量后,再计算就不保证精度啦。