# 整型(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);
}
}
```
总之来说就是,字面量怎么都计算都行,但一旦转为对应的变量后,再计算就不保证精度啦。
- Solidity语言
- 入门说明
- Solidity智能合约文件结构
- 智能合约源文件的基本要素概览
- 值类型
- 类型
- 布尔
- 整型
- 地址
- 字节数组
- 小数
- 字符串
- 十六进制字面量
- 枚举
- 函数
- 引用类型
- 引用类型
- 数据位置
- 数组
- 数据结构
- 杂项
- 映射
- 左值运算符
- 类型间的转换
- 类型推断
- 单位
- 货币单位
- 时间单位
- 语言内置特性
- 特殊变量及函数
- 数学和加密函数
- 地址相关
- 进阶
- 入参和出参
- 控制结构
- 函数调用
- 创建合约实例
- 表达式的执行顺序
- 赋值
- 作用范围和声明
- 异常
- 内联汇编
- 合约详解
- 合约
- 可见性或权限控制
- 访问函数
- 函数修改器
- 常状态变量
- 回退函数
- 事件
- 继承
- 接口
- 其它
- 库
- 状态变量的存储模型
- 内存变量的存局
- 调用数据的布局