博客
关于我
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两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>