IV 无规矩不成方圆,区块链的“规矩”是怎么起作用的?

大家好啊,我是豆小匠。

通过前面几期,我们知道区块链是一种非中心化的解决方案,没有“中央处理器”。

那么,区块链中的各种操作,比如转账、状态记录等规则是怎么定义,又是怎么起作用的呢?

本期主角 – “智能合约”(也叫智能合同)


1、智能合约是什么

区块链是一种分布式数据库,但是光有数据是不够的,我们还需要区块链自带数据的流转规则。

img

智能合约就是这个流转的规则, 它们可以表示各个参与方之间的协议。

智能合约的所有条款和条件都以编程方式定义。 定义将为区块链的参与者指定规则、要求和奖励。 它还会指定如何在各参与方之间传输数字资产。

因此从本质上讲,智能合约是一段程序,存储在区块链中,不可更改(但是可以升级合约)。

智能合约将自行运行,发送事件来触发状态转换,并调用函数。 它们非常适用于区块链技术,因为素不相识的人们可以通过它们按照指定的安全方式开展业务,而不需要任何中间商。


2、简单的智能合约示例

以以太坊(Ethereum)为例,它是全球首个可编程的区块链。可以通过它来定义智能合约,使用的语言是Solidity。

这里我们浅尝辄止,大概看下智能合约的组成部分:

pragma solidity >0.7.0 <0.8.0;

contract Marketplace {
  address public seller;
  address public buyer;
  mapping (address => uint) public balances;

  event ListItem(address seller, uint price);
  event PurchasedItem(address seller, address buyer, uint price);

  enum StateType {
    ItemAvailable,
    ItemPurchased
  }

  StateType public State;

  constructor() public {
    seller = msg.sender;
    State = StateType.ItemAvailable;
  }

  function buy(address seller, address buyer, uint price) public payable {
    require(price <= balances[buyer], "Insufficient balance");
    State = StateType.ItemPurchased;
    balances[buyer] -= price;
    balances[seller] += price;

    emit PurchasedItem(seller, buyer, msg.value);
  }
}

这是一个市场商品购买的合约,参与方是seller和buyer,他们的钱包金额保存在balances里。

代码从上往下解析:

  • 定义:

  • 三个状态变量:buyersellerbalances

  • 两个事件:ListItemPurchasedItem

  • 一个具有两个值的枚举:ItemAvailableItemPurchased

  • 构造函数将卖方用户指定为 msg.sender,并将初始状态设置为 ItemAvailable。 创建合约时,将调用此构造函数。

  • buy 函数有三个参数:seller``buyerprice。 这要求买方有足够的购买能力。 然后,它将资金从买方转移到卖方,并最终发出一条消息。


3、智能合约的执行流程

同样是用以太坊为例,合约制定人在编写完合约后,可以在以太坊部署(需要支付一定的手续费:“Gas”费用),剩下的就等待用户或者其他合约的调用触发,执行逻辑。

img

需要知道的是,合约一旦部署,代码和执行的结果无法被更改。也就是说即使合约出现bug,所产生的记录也是无法回滚的,只能通过其他手段做补偿机制,或者根本无法挽回。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值