以太坊是一个全球性的、去中心化的金融和新型应用程序平台。在以太坊,我们可以通过智能合约代码来控制资产,并建立世界上任何地方皆可访问的应用程序。今天我们自己动手来写一段简单的智能合约代码,探索一下智能合约的奥秘。
【智能合约】
智能合约(英语:Smart contract )是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。
智能合约的目的是提供优于传统合约的安全方法,并减少与合约相关的其他交易成本。
【EVM虚拟机】
以太坊虚拟机,是智能合约代码的执行器。 当智能合约被编译成二进制文件后,被部署到区块链上。 用户通过调用智能合约的接口,来触发智能合约的执行操作。 EVM执行智能合约的代码,修改当前区块链上的数据(状态)。
也就是说,以太坊上用来执行智能合约的执行器,有了它就可以执行智能合约.
【Solidity语言】
Solidity是以太坊虚拟机(EVM)智能合约的语言。我觉得Solidity是玩区块链项目必备的技能:区块链项目大部分是开源的,如果你能读懂代码,能帮你规避很多亏钱项目。
Remix是以太坊官方推荐的智能合约开发工具,适合新手,可以在浏览器中快速部署测试智能合约,你不需要在本地安装任何程序。
网址:remix.ethereum.org
【创建我的第一段智能合约】
进入remix,我们可以看到最左边的菜单有三个按钮,分别对应文件(写代码的地方),编译(跑代码),部署(部署到链上)。我们点新建(Create New File)按钮,就可以创建一个空白的solidity合约。
点击“新建”之后,在右边的编辑窗口填写一段智能合约代码
pragma solidity ^0.4.17;
contract Faucet {
function withdraw(uint amount) public {
require(amount <= 1000000000000000000);
msg.sender.transfer(amount);
}
function() public payable{}
}
这是一个模拟水龙头(Faucet)工作的智能合约。也就是用户在以太坊的测试网,通过水龙头领取测试币的过程。下面来详解这段合约的每一行:
第一行
pragma solidity ^0.4.17;
所有的 Solidity 源码都必须冠以 "version pragma" — 标明 Solidity 编译器的版本. 以避免将来新的编译器可能破坏你的代码。
当前的版本是Solidity 0.4.17
第二行
contract Faucet { }
contract 合约
Faucet 合约名称(可自定义)
{ }里面包含的内容,就是一份合约的基本模块。
Solidity 的代码都包裹在合约里面. 一份合约就是以太应币应用的基本模块, 所有的变量和函数都属于一份合约, 它是你所有应用的起点.
第三行
function withdraw(uint amount) public {
function 函数
withdraw(uint amount) 定义一个名称为withdraw的函数名,参数为unit(无符号整数类型)的amount
public 此函数是公开可见的,可以从外部调用
{ }里面是函数的内容
第四行
require(amount <= 1000000000000000000);
require 条件判断语句,如果语句为真(True)则执行,语句为假(False),则不执行。
amount <= 1000000000000000000 这里的amount表示以太币的数量,单位为wei。与比特币一样,以太币也不是无限可分的,以太币的最小单位是Wei。
第五行
msg.sender.transfer(amount);
msg.sender表示当前合约调用的地址
transfer(amount) 表示转账的数量
第六行
function() public payable{}
这是一个回退函数(Fallback Function)
一个合约可以有一个匿名函数。此函数不能有参数,不能返回任何值。如果没有其他函数与给定的函数标识符匹配,或者如果根本没有提供数据,将执行一个合约的调用。
此外,每当合同接收没有数据的纯Ether时,会执行回退函数。此外,为了接收Ether,回退函数必须标记为payable。如果没有这样的函数,合约不能通过常规transactions接收Ether。
通俗地讲,我们部署这个水龙头合约,是不需要转账ETH的,只需要花费gas。如果没有回退函数,合约不能通过常规transactions接收Ether。
【编译并部署代码】
点开编译的页面,选择版本,点击Compile那里。或者在编辑代码的页面,按ctrl+S就可以编译代码。
编译好之后,点击左侧菜单的“部署”按钮,进入部署页面。在默认情况下,Remix会用JS虚拟机来模拟以太坊链,运行智能合约,类似在浏览器里跑一条测试链。并且remix会分配几个测试账户给你,每个里面有100 ETH(测试代币)。你点Deploy(黄色按钮),就可以部署写好的合约了。
部署成功后,你会在下面看到名为faucet的合约,在最下面红色框里面,是部署的合约地址。智能合约一旦部署上链成功,就不可篡改。如果你修改后重新部署,那就是另外一个合约了。
这就是一段简单的智能合约代码,是不是很有趣? 希望本文对你有所帮助,让我们一起解锁更多的智能合约技术。
作者:SoloClover
推特:https://twitter.com/ZhiyuanQi
参考文献:
@0xAA_Science 《Solidity极简入门》GitHub - AmazingAng/WTFSolidity: 我最近在重新学solidity,巩固一下细节,也写一个“Solidity极简入门”,供小白们使用(编程大佬可以另找教程),每周更新1-3讲。