solidity二维数组详解

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]访问到的是12;通过T[1][0],T[1][1]访问到的是3,4,读取方式同C语言相同。

你可能感兴趣的:(以太坊,solidity)