区块链技术入门涉及那些编程语言?在本文中,将介绍比特币、超级账本 Fabric 和以太坊这三种区块链中,分别使用什么开发语言来进行智能合约编程,并提供你进一步学习的资源链接。

比特币

比特币是第一个真正意义上的区块链,不过,从严格意义上来讲,它对智能合约的开发者是不友好的。

可以用一种低门槛的编程语言Bitcoin Script在比特币系统上编写智能合约。每个比特币地址都对应着一个 Bitcoin Script 程序。看起来是这样:

IF 
    2 <Alices' pubkey> <Bob's pubkey> <Escrow's pubkey> 3 CHECKMULTISIG
ELSE
    "30d" CHECKSEQUENCEVERIFY DROP
    <Alices' pubkey> CHECKSIG
ENDIF

另一种较高级别的语言是 Ivy,它可以编译成 Bitcoin Script。Ivy 能够帮助你编写自定义的比特币地址,这种地址与隔离见证(SegWit)兼容,在比特币协议(包括签名检查、hash 特征值(commitment)和时间锁)的支持下,可以执行任意条件组合。例如:

contract EscrowWithDeplay{
    sender: PublicKey
    recipient: PublicKey,
    escrow: PublicKey,
    delay: Duration,
    val: Value
}{
    clause transfer(sig1: Signature, sig2: Signature){
        verify checkMultiSig([sender, recipient, escrow],[sig1, sig2])
        unlock val
    }
    clause timeout(sig: Signature){
        verify checkSig(sender, sig)
        verify older(delay)
        unlock val
    }
}

Ivy 的 github 地址:https://github.com/ivy-lang/ivy-bitcoin

比特币“虚拟机”——协议中负责执行 Bitcoin Script 程序的一部分——与以太坊或者 Chain Protocol 等其它智能合约平台的虚拟机相比(功能)更加有限,其指令系统甚至不是图灵完备的。但 Bitcoin Script 的确提供了一组很有用的基础原语(primitives)——签名校验、哈希计算以及相对和绝对的时间锁——另外还能对这些原语进行自由组合。

超级账本 fabric

fabric 是超级账本大家庭中最成熟的一个区块链项目,主要用于行业链、联盟联或私有链,它不需要通过挖矿来形成共识,因此可以达到很高的交易速度。

在 fabric 中,智能合约被称为链码(Chaincode),实质上是控制区块链网络中的不同实体或相关方如何相互交互或交易的业务逻辑。简言之,链代码将业务网络交易封装在代码中。可以调用链代码来设置和获取账本或 world state。

超级账本可以使用 go、java 或者 nodejs 来开发智能合约,不过支持最好的还是 go 语言。下面是使用 go 开发的一个简单地 fabric 智能合约:

package main

import "fmt"
import "github.com/hyperledger/fabric/core/chaincode/shim"

type SampleChaincode struct {
}

func (t *SampleChaincode) Init(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    return nil, nil
}

func (t *SampleChaincode) Query(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    return nil, nil
}

func (t *SampleChaincode) Invoke(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    return nil, nil
}

func main() {
    err := shim.Start(new(SampleChaincode))
    if err != nil {
        fmt.Println("Could not start SampleChaincode")
    } else {
        fmt.Println("SampleChaincode successfully started")
    }

}

frabric 的智能合约可以使用一个 go 中的类实现,它必须要实现约定的借口 Init 和 Query。

Init 方法 在链代码首次部署到区块链网络时调用,将由部署自己的链代码实例的每个对等节点执行。而只要在区块链状态上执行任何读取 / 获取 / 查询操作,就会调用 Query 方法。

访问这里了解更多关于 fabric 的智能合约开发的相关信息:Fabric Chaincode

以太坊

以太坊是第一个提供完善的智能合约开发框架的区块链,因此它也被称为区块链 2.0 的代表。事实上,目前绝大多数的区块链应用,包括 ICO 代币发行,都是基于以太坊来实现的智能合约应用。

以太坊有四种专用语言可以用来开发智能合约:

  • Solidity ,受 JavaScript 启发
  • Serpent ,受 Python 启发
  • Mutan,受 Go 启发
  • LLL, 受 Lisp 启发

这四种语言都是为面向合约编程而从底层开始设计的语言,但从目前的发展来看,Solidity 已经称为以太坊智能合约开发当之无愧的首选语言。

Solidity 的语法类似于 JavaScript,这降低了学习门槛,易于被掌握和使用,因为 JavaScript 是 Web 开发者的常用语言。例如,下面是一个使用 Solidity 开发的简单但完整的智能合约:

pragma solidity ^0.4.21;

contract HelloWorld {
    string hello = "Hello World!!!";
    event say(string _value);

    function sayHello() public {
        emit say(hello);
    }   
}

合约代码第一行指定该合约使用的 Solidity 版本为 0.4.21,不支持高于 0.4.21 版本的 Solidity 特性。

在 Solidity 中,contract 关键字包含的代码段即表示一个智能合约,它拥有一些成员变量和函数,看起来非常类似于传统的面向对象开发中的类。

如果你希望马上开始学习以太坊智能合约和应用开发,可以访问汇智网提供的出色的在线互动教程:

  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    85 引用 • 644 回帖 • 192 关注
  • 开发语言
    1 引用 • 4 回帖
  • 比特币

    比特币(BitCoin)的概念最初由中本聪在 2009 年提出,根据中本聪的思路设计发布的开源软件以及建构其上的 P2P 网络。比特币是一种 P2P 形式的数字货币。点对点的传输意味着一个去中心化的支付系统。

    34 引用 • 117 回帖 • 300 关注
  • fabric
    1 引用 • 4 回帖
感谢    赞同    分享    收藏    关注    反对    举报    ...