博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
星云链智能合约开发(八):智能合约中调用内置库
阅读量:6682 次
发布时间:2019-06-25

本文共 6164 字,大约阅读时间需要 20 分钟。

BigNumber

BigNumber 模块构建于 之上,用来处理任意精度的十进制和非十进制运算。合约可以直接使用 BigNumber 来处理交易和其他转账操作中涉及到的数值计算。

var value = new BigNumber(0);value.plus(1);…

Storage

storage 模块用来支持Nebulas上的数据持久化存储。功能上类似于传统的键值存储系统,当然存储不是免费的,需要消耗一定的 GAS。LocalContractStorage 是可以直接在合约中使用的内置storage对象,可存储的数据类型包括数字、字符串和 JavaScript 对象(需要序列化为字符串)。链上数据只能被存储它们的合约访问和修改。

基础

LocalContractStorage 支持三个操作:set、get`和 del,分别实现存储、读取和删除数据功能:“use strict”;var BankVaultContract = function () {  // nothing};BankVaultContract.prototype = {  init: function() {      // nothing  },  set: function(name, value) { // name=”robin”, value=10000      LocalContractStorage.set(“name”, name);      // put 操作相当于 set      LocalContractStorage.put(“value”, value);  },  get: function() {      var name = LocalContractStorage.get(“name”);      console.log(name);  // 打印 ‘robin’      var value = LocalContractStorage.get(“value”);     console.log(value); // 打印 ‘10000’  },  del: function() {      var result = LocalContractStorage.del(“name”);      console.log(result); // 打印 ‘robin’      // delete 操作相当于 del      result = LocalContractStorage.delete(“value”);      console.log(result); // 打印 ‘10000’      // 删除操作之后数据就不能被读取  }};module.exports = BankVaultContract;

进阶

除上述基本用法之外,LocalContractStorage还支持绑定以下两类链上存储空间到合约属性上:单值类型(storage property)和Map类型(storage map)。

单值存储(Storage Property)

只能存放一个值,对被绑定合约属性的读写都直接作用到LocalContractStorage 上。有两种方法可以定义这种绑定:

// 绑定一个单值存储空间到`obj` 上名为 `fieldName` 的属性 ,// descriptor定义了这个属性的序列化方法。//// 默认的 descriptor实现是 JSON.parse() 和 JSON.stringify()。// descriptor 为 ‘null’ 或 ‘undefined’时,默认 descriptor 将被使用。// return thisdefineProperty(obj, fieldName, [descriptor]);// 批量绑定多个单值存储空间到 `obj`// return thisdefineProperties(obj, {  fieldName1: descriptor1,  fieldName2: descriptor2});

通常我们会在初始化操作里完成绑定,如下所示:

“use strict”;var BankVaultContract = function () {   // 因为传值为 ‘null’,将会使用默认的 descriptor实现(序列化方法)   LocalContractStorage.defineProperty(this, “name1”, null);   // 一个自定义的 `descriptor` 实现   // 在解析的时候返回 BigNumber 对象   LocalContractStorage.defineProperty(this, “value1”, {       stringify: function (obj) {           return obj.toString();       },       parse: function (str) {           return new BigNumber(str);       }   });   // 用默认的序列化实现批量绑定   LocalContractStorage.defineProperties(this, {       name2: null,       value2: null   });};module.exports = BankVaultContract;

之后,读写绑定的属性就如同直接访问LocalContractStorage:

BankVaultContract.prototype = {   init: function(name, value) { // name=”robin”, value=1       this.name1 = name;       this.value1 = value;   },   testStorage: function(name, value) { // name=”ROBIN”, value=2       this.name2 = name;       this.value2 = value;       bool r = this.value1.lessThan(new BigNumber(0));       console.log(this.name1 + “:” + r);           // robin:false       console.log(this.name2 + “:” + this.value2); // ROBIN:2   }};

Map存储(Storage Map)

Nebulas 存储支持Map数据结构,有 del/delete、get 和 set/put这些操作,在遇到某些需要存储键值数据的场景时,就可以使用它。同样地,有两个方法来定义Map:

// 绑定单个map存储空间到名为`mapName`的合约属性,默认的 descriptor 实现和 defineProperty一样// 返回 thisdefineMapProperty(obj, mapName, [descriptor]);// 批量绑定// 返回 thisdefineMapProperties(obj, {   mapName1: descriptor1,   mapName2: descriptor2});

来看一个如何使用Map的例子:

‘use strict’;var BankVaultContract = function () {   LocalContractStorage.defineMapProperty(this, “userMap”);   LocalContractStorage.defineMapProperty(this, “userBalanceMap”, {       stringify: function (obj) {           return obj.toString();       },       parse: function (str) {           return new BigNumber(str);       }   });   LocalContractStorage.defineMapProperties(this,{       key1Map: null,       key2Map: null   });};BankVaultContract.prototype = {   init: function () {   },   testStorage: function () {       this.userMap.set(“robin”, “1”);       this.userBalanceMap.set(“robin”,new BigNumber(1));   },   testRead: function () {       // 读取和存储数据       var balance = this.userBalanceMap.get(“robin”);       this.key1Map.set(“robin”, balance.toString());       this.key2Map.set(“robin”, balance.toString());   }};module.exports = BankVaultContract;

Blockchain

Blockchain 模块用来获取当前正在执行的合约内的交易和区块信息。另外,还提供了若干有用的方法,诸如从合约账户中转出 NAS,进行地址格式验证等。

Blockchain 有两个属性:

  1. block 执行合约的当前区块,它具有下列属性:
    • timestamp 区块时间戳
    • height 区块高度
  2. transaction 执行合约的当前交易,它具有下列属性:
    • hash 交易哈希值
    • from 交易源地址
    • to 交易目的地址,对于合约调用就是合约地址
    • value 交易数值,字符串, 合约内用BigNumber存储计算
    • nonce 交易的 nonce 值
    • timestamp 交易时间戳
    • gasPrice 交易的 gasPrice,字符串,合约内用 BigNumber 存储计算
    • gasLimit 交易的 gasLimit,字符串,合约内用 BigNumber 存储计算

      Blockchain 还提供了两个方法:

  3. transfer(address, value) 将 NAS 从合约转出到address对应的账户。
    • 参数 address:接收 NAS 的 Nebulas 账户地址
    • 参数 value:转移数值,一个 BigNumber 对象
      返回:0 – 转移成功,1 – 转移失败
  4. verifyAddress(address) 验证参数 address 是否为一个有效的 Nebulas 地址。

返回:1 – 地址有效,0 – 地址无效

下面是用这个模块实现的简单实例:

‘use strict’;var BankVaultContract = function () {};BankVaultContract.prototype = {   init: function () {       console.log(‘init: Blockchain.block.height = ‘ + Blockchain.block.height);       console.log(‘init: Blockchain.transaction.from = ‘ + Blockchain.transaction.from);   },   transfer: function (address, value) {       var result = Blockchain.transfer(address, value);       console.log(“transfer result:”, result);   },   verifyAddress: function (address) {    var result = Blockchain.verifyAddress(address);       console.log(“verifyAddress result:”, result);   }};module.exports = BankVaultContract;

事件(Event)

Event 模块用来记录在合约执行过程中产生的事件。被记录的事件存储在链上的事件Trie结构中,可以通过事件查询方法 获取所有事件。通过Event模块输出的事件其最终Topic由用户自定义topic加固定前缀 chain.contract. 两部分构成 。使用方法如下:

Event.Trigger(topic, obj);· topic:用户定义的topic· obj:JSON 对象下面是示例:‘use strict’;var BankVaultContract = function () {};BankVaultContract.prototype = {   init: function () {},testEvent: function() {       // 实际被存储的topic是“chain.contract.topic”       Event.Trigger(“topic“, {   Data: {value: “Event test.”   }       });   }};module.exports = BankVaultContract;

控制台(Console)

console 模块提供了一个简单的调试控制台,类似于网页浏览器提供的 JavaScript 控制台。console 将把所有接收到的 args 以指定级别打印到 Nebulas Logger 上。

  • console.log([…args<any>]) — — info 级别
  • console.debug([…args<any>]) — — debug 级别
  • console.warn([…args<any>]) — — warn 级别
  • console.error([…args<any>]) — — error 级别
  • console.info([…args<any>]) — — console.log() 别名
    以上就是与智能合约相关的内置功能模块介绍。

转载于:https://blog.51cto.com/634435/2117168

你可能感兴趣的文章
2019前端面试题汇总(主要为Vue)
查看>>
js编程
查看>>
前端设计模式
查看>>
如何更优雅地切换Git分支
查看>>
ID3 算法介绍
查看>>
SpringBoot参数校验
查看>>
云HBase发布全文索引服务,轻松应对复杂查询
查看>>
码农张的Bug人生 - 目录
查看>>
学习webpack4 - 抽离公共代码
查看>>
【分享创造】react-typewriter-hook: 用react hooks来实现打字机的效果
查看>>
极限编程 (Extreme Programming) 和用户故事 (User Stories) 的关系
查看>>
coredns 排错记
查看>>
CentOS 7 安装 Nginx
查看>>
程序员毒鸡汤:我们都该学会正确的失败
查看>>
在 JavaScript 中优雅的提取循环内的数据
查看>>
HTML-语义类标签
查看>>
cookie、session、cache-control等
查看>>
YYCache 源码学习(二):YYDiskCache
查看>>
第十八天-企业应用架构模式-基本模式
查看>>
黑客图标
查看>>