以太坊是一个全球性的、去中心化的金融和新型应用程序平台。在以太坊,我们可以通过智能合约代码来控制资产,并建立世界上任何地方皆可访问的应用程序。今天我们自己动手来写一段简单的智能合约代码,探索一下智能合约的奥秘。

【智能合约】

智能合约(英语: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的合约,在最下面红色框里面,是部署的合约地址。智能合约一旦部署上链成功,就不可篡改。如果你修改后重新部署,那就是另外一个合约了。

这就是一段简单的智能合约代码,是不是很有趣” />https://twitter.com/ZhiyuanQi

参考文献:

@0xAA_Science《Solidity极简入门》GitHub – AmazingAng/WTFSolidity: 我最近在重新学solidity,巩固一下细节,也写一个“Solidity极简入门”,供小白们使用(编程大佬可以另找教程),每周更新1-3讲。