星云链Nebulas——4.智能合约存储区

2018-06-07  本文已影响83人  良__

前面一篇《星云链Nebulas——3.编译和部署智能合约》介绍了如何编写智能合约以及如何在星云链部署和调用智能合约。

本篇我们来详细的介绍有关星云链智能合约的存储。星云链智能合约(Smart Contract)提供了链上数据存储功能,类似于传统的Key-Value存储系统(如NoSQL、MongoDB、Redis等),可以付费(即消耗Gas)将数据存储到星云链上。

内置存储对象

星云链的智能合约运行环境内置了存储对象"LocalContractStorage",可以存储数字,字符串,JavaScript对象,存储数据只能在智能合约内使用,其他合约不能读取存储的内容。

1、基础用法

"LocalContractStorage"的简单接口包括"set","get","del"接口,实现了存储,读取,删除数据功能。存储可以是数字,字符串,对象。

2、高级用法

"LocalContractStorage"除了基本的"set","get","del"方法,还提供方法来绑定合约属性。对绑定过的合约属性的读写将直接在"LocalContractStorage"上读写,而无需调用"get"和"set"方法。

2.1 绑定属性

在绑定一个合约属性时,需要提供对象实例,属性名和序列化方法。

2.2 绑定Map属性

"LocalContractStorage"还提供了对合约中map属性的绑定方法。

2.3 Map数据遍历

在智能合约中如果需要遍历Map集合,可以采用如下方式:
定义两个map,分别是arrayMap,dataMap,arrayMap采用严格递增的计数器作为key,dataMap采用data的key作为key,详细参见set方法。
遍历实现参见forEach,先遍历arrayMap,得到dataKey,再对dataMap遍历。

由于Map遍历性能开销比较大,不建议对大数据量map进行遍历,建议按照limit,offset形式进行遍历,否者可能会由于数据过多,导致调用超时。

以下是遍历Map的例子:

"use strict";

var SampleContract = function () {
   LocalContractStorage.defineMapProperty(this, "arrayMap");
   LocalContractStorage.defineMapProperty(this, "dataMap");
   LocalContractStorage.defineProperty(this, "size");
};

SampleContract.prototype = {
    init: function () {
        this.size = 0;
    },

    set: function (key, value) {
        var index = this.size;
        this.arrayMap.set(index, key);
        this.dataMap.set(key, value);
        this.size +=1;
    },

    get: function (key) {
        return this.dataMap.get(key);
    },

    len:function(){
      return this.size;
    },

    forEach: function(limit, offset){
        limit = parseInt(limit);
        offset = parseInt(offset);
        if(offset>this.size){
           throw new Error("offset is not valid");
        }
        var number = offset+limit;
        if(number > this.size){
          number = this.size;
        }
        var result  = "";
        for(var i=offset;i<number;i++){
            var key = this.arrayMap.get(i);
            var object = this.dataMap.get(key);
            result += "index:"+i+" key:"+ key + " value:" +object+"_";
        }
        return result;
    }
};

module.exports = SampleContract;

本文参考:星云链Nebulas官方Github

下一篇

星云链Nebulas——5.通过RPC API和星云链交互

PS:刚入坑的小白,很多不懂,还请各位大佬多赐教,谢谢!

上一篇 下一篇

猜你喜欢

热点阅读