# 整型(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智能合約文件結構
- 智能合約源文件的基本要素概覽
- 值類型
- 類型
- 布爾
- 整型
- 地址
- 字節數組
- 小數
- 字符串
- 十六進制字面量
- 枚舉
- 函數
- 引用類型
- 引用類型
- 數據位置
- 數組
- 數據結構
- 雜項
- 映射
- 左值運算符
- 類型間的轉換
- 類型推斷
- 單位
- 貨幣單位
- 時間單位
- 語言內置特性
- 特殊變量及函數
- 數學和加密函數
- 地址相關
- 進階
- 入參和出參
- 控制結構
- 函數調用
- 創建合約實例
- 表達式的執行順序
- 賦值
- 作用范圍和聲明
- 異常
- 內聯匯編
- 合約詳解
- 合約
- 可見性或權限控制
- 訪問函數
- 函數修改器
- 常狀態變量
- 回退函數
- 事件
- 繼承
- 接口
- 其它
- 庫
- 狀態變量的存儲模型
- 內存變量的存局
- 調用數據的布局