区块链踩坑之智能合约代币编写及使用介绍

连载篇提前看

系列文章一:区块链踩坑之基础扫盲及搭建以太坊网络私有链(单节点)

系列文章二:区块链踩坑之搭建以太坊网络私有链(多节点)及创建多重签名钱包

系列文章三:区块链踩坑之智能合约代币编写及使用介绍

前言

上篇文章我们搭建了以太坊网络私有链,实现了多节点间的转账交易以及了解和使用了多重签名钱包。本篇 我们将继续深挖,共同探讨智能合约部分。首先我们要编写以太坊的只能合约,那就得先了解下Solitidy 语言。戳官网 http://solidity.readthedocs.io/en/develop/index.html

Solitidy简单介绍:

●它是一个面向合约的高级语言,其语法类似于JavaScript。是运行在以太坊虚拟机中的代码。

●它是静态类型的编程语言,编译期间会检查其数据类型。支持继承、类和复杂的用户定义类型。

●在线体验:https://remix.ethereum.org

一个面向数字加密货币最简单的合约代码示例如下:

pragma solidity ^0.4.21;

contract Coin {
    // The keyword "public" makes those variables
    // readable from outside.
    address public minter;
    mapping (address => uint) public balances;

    // Events allow light clients to react on
    // changes efficiently.
    event Sent(address from, address to, uint amount);

    // This is the constructor whose code is
    // run only when the contract is created.
    function Coin() public {
        minter = msg.sender;
    }

    function mint(address receiver, uint amount) public {
        if (msg.sender != minter) return;
        balances[receiver] += amount;
    }

    function send(address receiver, uint amount) public {
        if (balances[msg.sender] < amount) return;
        balances[msg.sender] -= amount;
        balances[receiver] += amount;
        emit Sent(msg.sender, receiver, amount);
    }
}

部署合约

① 创建一个新合约,具体步骤如下:

 

点击部署

 

确认后,主页面将显示合约创建成功

回到合约界面,此时合约已经创建成功

我们执行后返回主界面,已经有2个矿工确认该项交易 合约执行成功

我们复制下主账户地址,然后到合约里面查询下合约币数是否已到账

从合约中发送交易

 我们现在从合约中给a节点子账户发送一笔交易(此时ACCOUNT2账户余额是为0的)

 

 

执行成功后,我们复制下Account2地址,在合约中查询下Account账户情况:

以上操作都是再同节点操作,下面我们尝试向不同节点发送合约交易

交易后我们查询下 主账户合约余额是否正确

 

 至此,智能合约部署 和使用已经全部讲完。 接下来 我们将深入探讨学习和使用Solidity 编写智能合约以及其他应用。

 

未完待续。。。。

 

posted @ 2018-05-11 11:13  潇十一郎  阅读(1201)  评论(0编辑  收藏  举报