智能合约的技术运作原理解析

网友投稿 1087 2023-02-08

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

智能合约的技术运作原理解析

好!那本文便开始啰!我们直接开门见山地来谈谈:

何谓智能合约?

智能合约本质上是一段部署 ( Deploy,即发布) 到区块链上的程式码,因为区块链上的程式码(严格来说是二进位码)可以被检视,所以具备公开透明的特性。智能合约被部署到链上后会产生一个合约地址,永久存在于链上的区块之中。以下用Pelith开发部署之CryptoCow智能合约为范例做解说。

如何部署智能合约?

我们从智能合约的诞生谈起。

开发者将程式码开发完成后,要透过发送一笔接收地址为“0x0”开头的交易(一般交易的接收地址为0x开头,后面接一串字),并在交易的 Input Data内放上开发完成的程式码。矿工看到接收地址为0x0的交易就会知道交易的发送者想要部署智能合约,随后便会将Input Data内的程式码部署到区块链上,并生成一个合约地址。

至此,我们来整理一下部署智慧合约上链的流程:

1. 开发者以Solidity 编写完成合约

2. 原始码编译为Bytecode

3. 放入交易的Input Data 中

4. 接收地址部分留空(0x0)

5. 节点(矿工) 判定为要发送合约上链

6. 矿工执行,并部署上链生成智慧合约

7. 合约拥有自己的「合约地址」,永久存在链上

什么是合约地址?

在合约生成之后,会创造出一个合约地址,让合约(Contract Account)和个人帐户(Externally Owned Account)一样都有一个地址,会纪录追踪nonce(帐户的交易次数)和balance(帐户余额)。

不过合约因为是「被」创造出来的,不像个人帐户一样可以「主动操作」来发送交易给别人,所以我们如果要使用智慧合约的功能,必须要以个人帐户发送一笔「接收地址为合约地址」的交易,来主动触发合约,让合约执行动作。

因此,任何一笔交易的起点都必须是个人帐户。

接着,我们来实际看看一笔和智能合约互动的交易,下方是一笔很常见的操作合约交易,内容是将一颗透过智能合约创造出来的ERC-20 代币,从一个地址转移到另一个地址中。而这些操作,必须透过交易发起者将这些操作以程式原始码撰写,编译后放到Input Data 中。

如果不确定这个MethodID是什么功能或会做什么,可以到Ethereum Function Signature Database 上查询:

把0x93316cdf 贴上并搜寻后,便能得知这个MethodID 对应的是什么function,可以再以这个function 到智慧合约的程式码中去确认到底操作了什么。

结论

智能合约是一段部署到区块链上的程式码,可以有各式各样的功能。因为区块链公开透明的特性,所以可以被任何人检视和验证。

合约部署完成后会生成「合约帐户」,有自己的合约地址。但所有的交易与操作都必须「个人帐户」发起,去呼叫合约中的function来执行。

想要确认操作合约的交易到底做了什么,可以检视Input Data内0x后的前八码 MethodID,并查询这是什么 function,再到合约帐户中去检视原始码来确认。

上一篇:Qualcomm推出骁龙智能头显参考设计
下一篇:智能语音技术在医疗领域的成熟应用
相关文章

 发表评论

暂时没有评论,来抢沙发吧~