区块链之智能合约 solidity踩坑 --上篇

Posted chenshouchang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了区块链之智能合约 solidity踩坑 --上篇相关的知识,希望对你有一定的参考价值。

概述

最近在写合约时遇到一些坑,做一下总结;

介绍主要分一下三个方面:

  • 对区块链的简单描述
  • 结合业务场景,编写简单智能合约,时遇到的坑(上篇)
  • assembly 的使用说明(下篇)

正文

进入正题之前,我稍微简单介绍一下什么是区块链,区块链干嘛用的(特点),智能合约是做什么的,为什么要写只能合约(一下是个人理解仅供参考)

什么是区块链

A blockchain is a globally shared, transactional database.

译文:区块链是一个全局共享的事物数据库;(就是个数据库)

区块链特点

既然当前区块链这么火,那么总要有火的理由吧,它到底用来干什么的呢?而体现区块链本身的商业价值,说白了就是能靠它的独有的特点赚钱;

  • 分布式结构
  • 信任机制
  • 公开透明
  • 时序不可篡改

区块链工作原理

  1. 客户端将发起一笔交易,经数字签名后广播给网络上的其他节点并等待确认
  2. 网络中的节点对收到的数据记录信息进行校验,通过校验后,数据记录到一个区块中
  3. 全网所有接受节点对区块执行共识算法,区块通过共识算法过程后正式纳入区块链中存储,全网节点均表示接受该区块。表示接受的方法,是将该区块的随机哈希值视为最新的去区块哈希值,新去块将提供永久和透明的交易记录并以该区块链为基础进行延长,实现资金转移。

什么是智能合约

A contract in the sense of Solidity is a collection of code (its functions) and data (its state) that resides at a specific address on the Ethereum blockchain.

译文:Solidity意义上的合约是代码(其功能)和数据(其状态)的集合,它位于以太坊区块链的特定地址。

关键字:code (its functions) 、 data (its state)、address

踩坑

在写合约时遇到一下几个问题; 其实这些问题google上都能查到,但也是需要大量时间,有些还不一定对,小编对下述问题做一个总结与归纳;以后也给自己方便;

  1. 合约方法能返回struct结构吗? 能要怎么做?

答:Yes, but only in internal function calls.

使用 internal 时,与平时的 function 写法一样即可

  1. 合约方法能对string进行字符串拼接操作吗?

答:You have to do it manually for now.

说白了就是没有,要自己实现; 方案1:https://github.com/Arachnid/solidity-stringutils/blob/master/src/strings.sol

方案2:这是小编根据google查得做了一些小改的,仅供参考

   /// 内部访问函数,internal
   /// 实现将string _a, _b1,_b2,_c拼接成一个string
   function strConcat(string _a, bytes1  _b1,bytes1 _b2, string _c) internal pure returns (string){
       bytes memory _ba = bytes(_a);
      bytes memory _bc = bytes(_c);
       string memory abcde = new string(_ba.length + _b1.length + _b2.length + _bc.length);
       bytes memory babcde = bytes(abcde);
       uint k = 0;
       for (uint i = 0; i < _ba.length; i++) babcde[k++] = _ba[i];
       for (i = 0; i < _b1.length; i++) babcde[k++] = _b1[i];
       for (i = 0; i < _b2.length; i++) babcde[k++] = _b2[i];
       for (i = 0; i < _bc.length; i++) babcde[k++] = _bc[i];
       return string(babcde);
   }
  1. 合约方法能返回数组类型吗?

答:可以,但不能返回动态数组; 什么意思呢,就是说可以 int[] uint[] 等等,如果是string[] 则需要给string []定length长度,否则编译失败; 那么业务上就需要 returns(string[])怎么办? 小编的解决方案是return string来代替,将每一个string拼接起来,拼接符可以用ASCII码中不可见字符如:0x01,0x02等等,千万别用常见字符;(之前做hyperledger fabric的java sdk解析时发现也用到了)

说明编码这里顺带说一句,

All identifiers(contract names,function names and variable names) are 
restricted to the ASCII character set. It is possible to store UTF-8 
encoded data in string variables.
  1. 能对address 类型进行算术操作吗?

答:The address type is a 160-bit value that does not allow any arithmetic operations.

  1. solidity 的版本会影响 evm的编译吗?

答:据我所知,没有影响,因为对evm来说它只是执行了,solidity通过solc编译之后产生的bin、abi文件,进行编译;

solidity的版本若高于solc编译环境的版本则会无法编译

本文篇幅没啥干货,就随意聊聊浅谈一下;

以上是关于区块链之智能合约 solidity踩坑 --上篇的主要内容,如果未能解决你的问题,请参考以下文章

区块链开发之Solidity智能合约开发

Solidity智能合约单元测试介绍

Solidity智能合约单元测试介绍

区块链Solidity智能合约语言学习笔记

区块链-智能合约工程师第二篇:Solidity入门

区块链-智能合约工程师第二篇:Solidity入门