泰岳区块链---YRC20合约(ERC20)

YRC20(Yue Request for Comment)合约本质是一个地址+数字(token数量)的记账本。这个记账本有几个一些标准的函数。形成了一个YRC20的标准。标准有什么好处呢?标准可以让其他的应用很好的兼容,不用针对你的TOKEN再做一个特殊处理。

简单点:你可以定义一个自己的合约,里面就存一些地址+数字(token数量)的合约,其他都可以不用。默认一些参数。一些函数,也是可以成为合约TOKEN的。

我们介绍一下标准的。我们看一下。针对代码一个个解释
下面是一个比较简单的标准YRC20后,后续给大家带来一个复杂点的。语法多一点的

pragma solidity ^0.6.0;
  // SPDX-License-Identifier: MIT 
  library SafeMath {//安全函数--合约安全性
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
      assert(b <= a);
      return a - b;
    }
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
      uint256 c = a + b;
      assert(c >= a);
      return c;
    }
  }
  
  contract Neotoken {
    using SafeMath for uint256; // 让uint256 都可以使用 SafeMath library
    string public constant name = "TUSDTEST";  // 代币的名称
    string public constant symbol = "USDT"; // 代币的简称
    uint256 public constant decimals = 6; // 代币的位数,Tai是18位,这个是6位,也就是1000000 这个值表示1个USDT
    uint256 public constant totalSupply = 100000000000000000000000000; // 表示总数量
    mapping (address => uint256) private balances; //这个就是存储用户token的账本
    mapping (address => mapping (address => uint256)) private allowed; //这个是用来存储allowed数量的地址
    event Transfer(address indexed _from, address indexed _to, uint256 _value); // 这是发送的EVENT
    event Approval(address indexed _owner, address indexed _spender, uint256 _value); // approval方法是允许别人转token
    constructor() public { //构造函数
      balances[msg.sender] = totalSupply;
    }
    // 查询余额的方法
    function balanceOf(address _owner) public view returns (uint256 balance) {
      return balances[_owner];
    }
    //转账方法
    function transfer(address _to, uint256 _value) public returns (bool success) {
     // require (_to != 0x0, "");
      require((balances[msg.sender] >= _value), "");
      balances[msg.sender] = balances[msg.sender].sub(_value);
      balances[_to] = balances[_to].add(_value);
      emit Transfer(msg.sender, _to, _value);
      return true;
    }
    // 转别人的token方法,前提别人必须先approval
    function transferFrom(address _from, address _to, uint256 _value) public returns (bool success) {
      require (_to != address(0), ""); 
      require(balances[_from] >= _value && allowed[_from][msg.sender] >= _value, "not eng aaa");
      allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
      balances[_from] = balances[_from].sub(_value);
      balances[_to] = balances[_to].add(_value);
      emit Transfer(_from, _to, _value);
      return true;
    }
    // 允许别人转账方法
    function approve(address _spender, uint256 _value) public returns (bool success) {
      allowed[msg.sender][_spender] = _value;
      emit Approval(msg.sender, _spender, _value);
      return true;
    }
    // 查看允许别人转账的金额
    function allowance(address _owner, address _spender) public view returns (uint256 remaining) {
      return allowed[_owner][_spender];
    }
  }
上一篇:116孤荷凌寒自学第0202天_区块链第116天NFT013


下一篇:装饰器和生成器