博客
关于我
ERC20
阅读量:553 次
发布时间:2019-03-09

本文共 1572 字,大约阅读时间需要 5 分钟。

ERC20

ERC20是一套发行的token标准,可以让Token的发行变得非常容易,甚至可以做到5分钟之内就发行一种新的Token。以太坊上的token种类很多,这么多token的标准不统一的话也就没办法办到token之间的交易以及多种token的钱包。所以,有了ERC20这样统一的标准,有利于Token的流通以及相关产品(比如钱包、交易平台)的开发。它本身就是以太坊上的智能合约。

为了充分兼容 ERC20,开发者需要将一组特定的函数(接口)集成到他们的智能合约中。

ERC20标准(标准接口)

方法:

name:
function name() constant returns (string name)

返回ERC20 token的名字,例如:ShowCoin

symbol:
function symbol() constant returns (string symbol)

返回ERC20 token的缩写简称,例如:SHOW

decimals(可选):
function decimals() constant returns (uint8 decimals)

返回支持小数点后几位。 比如 8,表示分配token数量为100000000。

totalSupply
function totalSupply() constant returns (uint256 totalSupply)

返回发行 token的总量

balanceOf
function balanceOf(address _owner) constant returns (uint256 balance)

返回地址是_owner的账户的账户余额。

transfer
function transfer(address _to, uint256 _value) returns (bool success)

转移_value的token数量到的地址_to,并且必须触发Transfer事件。 如果_from帐户余额没有足够的令牌来支出,该函数应该被throw。

创建新令牌的令牌合同应该在创建令牌时将_from地址设置为0x0触发传输事件。

approve
function approve(address _spender, uint256 _value) returns (bool success)

批准一账户从自己的账户花费_value个token。可以分多次转移。

transferFrom
function transferFrom(address _from, address _to, uint256 _value) returns (bool success)

approve批准花费之后,调用transferFrom函数来转移token。

allowance
function allowance(address _owner, address _spender) constant returns (uint256 remaining)

返回一账户还能提取token的个数。

事件

Transfer
event Transfer(address indexed _from, address indexed _to, uint256 _value)

从地址_from发送数量为_value的token到地址_to,必须触发Transfer事件。

转移成功时,必须要触发Transfer事件

Approval
event Approval(address indexed _owner, address indexed _spender, uint256 _value)

调用approval函数成功时,必须要触发Approval事件

转载地址:http://krosz.baihongyu.com/

你可能感兴趣的文章
MySQL配置文件深度解析:10个关键参数及优化技巧---强烈要求的福利来咯。
查看>>
Mysql配置表名忽略大小写(SpringBoot连接表时提示不存在,实际是存在的)
查看>>
mysql配置读写分离并在若依框架使用读写分离
查看>>
MySQL里为什么会建议不要使用SELECT *?
查看>>
MySQL里的那些日志们
查看>>
mysql重新安装?忘记root密码?重装Windows、Linux系统导致mysql没法用吗? 这里有你想要的答案
查看>>
mysql重置root密码
查看>>
MySQL锁
查看>>
MySQL锁与脏读、不可重复读、幻读详解
查看>>
MySQL锁机制
查看>>
mysql锁机制,主从复制
查看>>
Mysql锁机制,行锁表锁
查看>>
MySQL锁表问题排查
查看>>
Mysql锁(1):锁概述和全局锁的介绍
查看>>
Mysql锁(2):表级锁
查看>>
MySQL锁,锁的到底是什么?
查看>>
MySQL错误-this is incompatible with sql_mode=only_full_group_by完美解决方案
查看>>
Mysql错误2003 -Can't connect toMySQL server on 'localhost'(10061)解决办法
查看>>
MySQL错误提示mysql Statement violates GTID consistency
查看>>
mysql错误:This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de
查看>>