solidity二维数组详解
今天认真研究了一下solidity的二维数组,发现这个数组的定义不同之前了解过的语言定义方式
定义方式
固定长度数组
首先来看一下固定长度数组的定义方式
uint[2][3] T =[[1,2],[3,4],[5,6]];
我们可以知道uint[2][3]
中,[2]表示一维数组的长度,[3]表示二维数组可以存放多少个一位数组;
但是内存是怎么存放的呢?
还不知道,我们通过动态的二维数组来了解一下
动态长度数组
pragma solidity ^0.4.4;
contract C{
uint[2][] public T= new uint[2][](0);//这里我们定义了一个二维数组;一维长度为2,二维长度未定
//这个函数可以通过运行,说明动态二维数组中,二维数组中可以添加一个新的一位数组。
//我们可以想象大概模样是这样的【图一】
//首先添加一维数组[1,2],然后再次添加一维数组[3,4]
function pushArr(uint[2] t){
T.push(t);
}
function getLength()constant returns(uint){
return T.length;
}
//通过下面这个函数我们再次确认【图一】是否正确
//输入0给的结果是1 2 ,输入 1 给的结果是 3 4
function getNumber(uint index) constant returns(uint,uint){
return (T[index][0], T[index][1]);
}
}
图一
行列 | - | - |
---|---|---|
- | 第0列 | 第1列 |
第0行 | 1 | 2 |
第1行 | 3 | 4 |
结论:内存存储。从结果上来看,内存分布如【图一】所示,uint[2][3]相当于在一个长度为【三】的一维数组里添加【三】个长度为【二】的一维数组。如此这般。
结论:读取。从读取情况,可以知道,我们通过T[0][0]``T[0][1]
访问到的是1
,2
;通过T[1][0]
,T[1][1]
访问到的是3
,4
,读取方式同C语言相同。