EOS智能合约案例解析(1)

为了帮助大家熟悉 EOS 智能合约,EOS 官方提供了一个代币(资产)智能合约 Demo —— eosio.token。eosio.token 智能合约目前还不是特别完善,个别功能还没有完成。但这个示例合约给出了 EOS 官方智能合约开发的标准结构和开发方法,并且真正的 EOS 代币也会借鉴这个示例合约的逻辑,是 EOS 智能合约入门的经典案例。

照例,eosio.token 合约由三个文件(cpp,hpp,abi)文件组成,本篇文章将为大家讲解 eosio.token.hpp 文件。原文件地址:https://github.com/EOSIO/eos/tree/master/contracts/eosio.token

预处理指令 & 头文件

代码的开头声明了头文件,主要是 eos 智能合约的 API 库。

//预处理指令,防止文件被重复包含#pragma once//eos 资产(asset)头文件#include <eosiolib/asset.hpp>//eos 智能合约 API 库#include <eosiolib/eosio.hpp>

构造函数

智能合约的类名可以与智能合约名不同,智能合约的名字是其账户名。构造函数为空,参数为智能合约账户名。

   //每个智能合约类都要继承 contract 类
   class token : public contract {      public:         //类构造函数
         token( account_name self ):contract(self){}

创建代币函数(action)

声明 create 函数,这个函数用来新建一种代币,并输入代币的各种属性,同时 create 函数也是一个 action。action 是 eos 智能合约的接口函数,定义外界可以对智能合约做什么动作。

                      //参数:发币者
         void create( account_name issuer,                      //资产最大数目
                      asset        maximum_supply,                      //资产是否可以冻结
                      uint8_t      issuer_can_freeze,                      //资产是否可以召回
                      uint8_t      issuer_can_recall,                      //资产是否可以设置白名单
                      uint8_t      issuer_can_whitelist );

增发代币函数(action)

声明 issue 函数,这个函数用来增发代币,eosio.token 合约并不是新建了代币就会得到代币,新建的代币只是存储了资料,发币者要想获取代币,需要调用 issue action 来获得代币。

         //参数:接收新代币账户,新增多少代币,memo
         void issue( account_name to, asset quantity, string memo );

转账函数(action)

声明 transfer 函数,这个函数用来转账,是代币智能合约最常用的函数。

                        //发送账户
         void transfer( account_name from,                        //接收账户
                        account_name to,                        //代币数量
                        asset        quantity,                        //memo
                        string       memo );

私有数据结构

智能合约需要存储每种代币的资料,还要存储每个账户持有每种代币的数量。

      private:         //account 结构体,单个记录账户存储单个代币的情况
         struct account {            //资产余额
            asset    balance;            //账户是否冻结
            bool     frozen    = false;            //账户是否在白名单
            bool     whitelist = true;            //设置账户主键为代币名称
            uint64_t primary_key()const { return balance.symbol.name(); }
         };         //currency_stats 结构体,记录当代币状态信息
         struct currency_stats {            //流通量
            asset          supply;            //最大可流通量
            asset          max_supply;            //发币者
            account_name   issuer;            //是否可以冻结
            bool           can_freeze         = true;            //是否可以召回
            bool           can_recall         = true;            //是否可以设置白名单
            bool           can_whitelist      = true;            //是否已经冻结
            bool           is_frozen          = false;            //是否已经设置白名单
            bool           enforce_whitelist  = false;            //设置主键为代币名称
            uint64_t primary_key()const { return supply.symbol.name(); }
         };         //设置一个multi_index类型,存储 account 结构体
         typedef eosio::multi_index<N(accounts), account> accounts;         //设置一个multi_index类型,存储 currency_stats 结构体
         typedef eosio::multi_index<N(stat), currency_stats> stats;

私有函数

合约公有两个私有函数,分别是给账户增加某种资产,和给账户减少某种资产。

         //增加资产函数:账户,增加数量,代币状态结构体
         void sub_balance( account_name owner, asset value, const currency_stats& st );         //减少资产函数:账户,减少数量   ,代币状态结构体
         void add_balance( account_name owner, asset value, const currency_stats& st,                           //ram 资源支付者
                           account_name ram_payer );

原文地址:http://blog.51cto.com/13625500/2119051

时间: 2024-10-08 16:10:16

EOS智能合约案例解析(1)的相关文章

EOS 智能合约案例解析(3)

详解 EOS 智能合约的 abi 文件 这次向大家介绍 eosio.token 智能合约的最后一个文件 -- abi文件.ABI 全称 Application Binary Interface,中文名"应用程序二进制接口",顾名思义是一个接口文件,描述了智能合约与上层应用之间的数据交换格式.abi 文件格式类似 JSON,具备很好的可读性,有利于智能合约工程师与上层应用工程师之间的工作衔接.eosio.token.abi 文件地址: https://github.com/EOSIO/e

EOS 智能合约案例解析(2)

详解 EOS 智能合约的 cpp 文件 之前的文章介绍了 eosio.token 智能合约的 hpp 文件,这次向大家介绍 eosio.token.cpp 文件,cpp 文件即 C++ 代码文件,智能合约所有的业务逻辑内容都是在 cpp 文件中实现的. eosio.token.cpp 文件地址: https://github.com/EOSIO/eos/blob/master/contracts/eosio.token/eosio.token.cpp 了解 C/C++ 开发的同学肯定熟悉,cpp

EOS智能合约开发(三):EOS创建和管理账号

没有看前面文章的小伙伴可以看一下 EOS智能合约开发(一):EOS环境搭建和启动节点 EOS智能合约开发(二):EOS创建和管理钱包 创建好钱包.密钥之后,接下来你就可以创建账号了,账号是什么?账号保存在区块链上的人类可读的标志符. 创建账号的命令: $ cleos createaccount eosio ${new_account} ${owner_key} ${active_key} 其中eosio是超级用户,需要靠超级用户来创建其它的新用户,eosio后面就是你的新用户的用户名. 除了新的

【刘文彬】【精解】EOS智能合约演练

原文链接:醒者呆的博客园,https://www.cnblogs.com/Evsward/p/eos-contract.html EOS,智能合约,abi,wasm,cleos,eosiocpp,开发调试,钱包,账户,签名权限 热身 本文旨在针对EOS智能合约进行一个完整的实操演练,过程中深入熟悉掌握整个EOS智能合约的流程,过程中出现的问题也会及时研究并入我们自己的知识体系.本文会主要跟随EOS官方Wiki的智能合约部分进行研究学习,主要分为 开启一个私有链 创建钱包 载入基础IO的智能合约支

【精】EOS智能合约:system系统合约源码分析

系统合约在链启动阶段就会被部署,是因为系统合约赋予了EOS链资源.命名拍卖.基础数据准备.生产者信息.投票等能力.本篇文章将会从源码角度详细研究system合约. 关键字:EOS,eosio.system,智能合约,name类型,native.hpp,newaccount,bidname,core token init,onblock,更新已入选生产节点 eosio.system 概览 笔者使用的IDE是VScode,首先来看eosio.system的源码结构.如下图所示. 本文分析的源码来自于

eos智能合约开发最佳实践

安全问题 1.可能的错误 智能合约终止 限制转账限额 限制速率 有效途径来进行bug修复和提升 2.谨慎发布智能合约 对智能合约进行彻底的测试 并在任何新的攻击手法被发现后及时制止 赏金计划和审计合约 3.合约的简介 确保智能合约逻辑简单 确保合约和函数模块化 4.保持更新 在任何新发现的漏洞之前进行修复 利用最新技术 5.潜在特性 可能会调用同名函数 漏洞 溢出漏洞 typedef struct acnts { account_name name0; account_name name1; a

以太坊去中心化淘宝智能合约案例

篇文章我们来介绍一个简易的区块链电商系统的核心功能,10多年来,我们习惯了淘宝的电商模式,淘宝为电商在中国普及做出了突出贡献,值得肯定,也完成了历史使命. 淘宝模式的核心是什么? 免费是一方面,我认为最核心的是解决了网上交易买卖家的信任问题,通过支付宝作为资金中介,使买卖家可以放心的交易. 但是,淘宝迅速崛起为巨头后,交易环节出现了很多不好的现象:刷信誉.巨大经济利益带来的内部腐败等等.因此,淘宝虽然成为了电商巨头,但是却没有真正的解决电商产业的信誉问题.这个问题其实不是淘宝特有,是一种社会现象

智能合约bug以及修改方案

截取两篇文章:第一遍文章说的是智能合约能不能修改的问题: ETC转到ETH地址以及转币进ETH智能合约账户能不能转出来? 第0章 引言 如果ETC充值到了ETH地址上,能找回来吗?答案是不一定. ETH转到别的ETH地址上,也是有可能再也弄不出来的. 第1章 以太坊的两类账户 以太坊有两类账户,外部账户和合约账户. 外部账户是由公钥和私钥组成的.我们绝大多数用户生产的以太坊钱包都属于这一类账户,私钥可以决定这个账户里的币,包括以太坊和ERC20币. 合约账户是由一个地址和对应存储的一些代码组成的

十分钟部署智能合约

eos环境搭建 1.git clone源代码 git clonehttps://github.com/EOSIO/eos --recursive 2.下载编译之后,里面有三个应用程序,这三个应用程序也都是命令行的: 1.Cleos: 2.Nodeos: 3.Keosd. 这三个应用程序之间有什么关系呢?我们现在使用的前端,怎么使用EOS呢? -Cleos,它是一个命令行程序.在前端使用EOS是通过Cleos输入命令,给EOS下达指令. -Nodeos,其实它就是挖矿客户端.在启动Nodeos之后