构建 ERC20 代币合约

国跃
2023-12-01

构建 ERC20 代币合约

使用 Contracts,我们可以轻松创建我们自己的 ERC20 代币合约,该合约将用于跟踪假设游戏中的内部货币黄金(GLD)。

这就是我们的 GLD 代币的样子。

// contracts/GLDToken.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import "@openzeppelin/contracts/token/ERC20/ERC20.sol";

contract GLDToken is ERC20 {
    constructor(uint256 initialSupply) ERC20("Gold", "GLD") {
        _mint(msg.sender, initialSupply);
    }
}

我们的合约通常通过继承使用,在这里我们重用ERC20了基本标准实现和可选扩展。此外,我们正在创建一个of 令牌,它将被分配到部署合约的地址。namesymboldecimalsinitialSupply

有关 ERC20 供应机制的更完整讨论,请参阅创建 ERC20 供应

而已!部署后,我们将能够查询部署者的余额:

> GLDToken.balanceOf(deployerAddress)
1000000000000000000000

我们还可以这些代币转移到其他账户:

> GLDToken.transfer(otherAddress, 300000000000000000000)
> GLDToken.balanceOf(otherAddress)
300000000000000000000
> GLDToken.balanceOf(deployerAddress)
700000000000000000000

关于decimals

通常,您会希望能够将您的代币分成任意数量:比如说,如果您拥有5 GLD,您可能想要发送1.5 GLD给朋友,并自己保管3.5 GLD。不幸的是,Solidity 和 EVM 不支持这种行为:只能使用整数(整数),这会带来问题。您可以发送12令牌,但不能1.5

为了解决这个问题,ERC20提供了一个decimals字段,用于指定令牌有多少个小数位。为了能够转移1.5 GLDdecimals必须至少是1,因为该数字只有一个小数位。

如何实现?其实很简单:一个代币合约可以使用更大的整数值,这样一个50will的余额代表5 GLD,一个will的转账15对应1.5 GLD发送,等等。

了解decimals用于显示目的很重要。合约内部的所有运算仍然是对整数进行的,而且是不同的用户界面(钱包、交易所等)必须根据 调整显示的值decimals。每个账户的总代币供应量和余额未在 中指定GLD:您需要除以10 ** decimals得到实际GLD数量。

您可能希望使用 的decimals18,就像 Ether 和大多数正在使用的 ERC20 代币合约一样,除非您有非常特殊的理由不这样做。在铸造代币或转移代币时,您实际上是在发送数字num GLD * (10 ** decimals)

默认情况下,ERC20使用值18for decimals。要使用不同的值,您需要重写decimals()合约中的函数。
function decimals() public view virtual override returns (uint8) {
  return 16;
}

因此,如果您想5使用 18 位小数的代币合约发送代币,调用的方法实际上是:

transfer(recipient, 5 * (10 ** 18));

预设ERC20合约

可以使用预设的 ERC20 ERC20PresetMinterPauser,。它被预设为允许代币铸造(创建)、停止所有代币传输(暂停)并允许持有者销毁(销毁)他们的代币。该合约使用访问控制来控制对铸造和暂停功能的访问。部署合约的账户将被授予 minter 和 pauser 角色,以及默认的 admin 角色。

该合约已准备好部署,无需编写任何 Solidity 代码。它可以按原样用于快速原型设计和测试,但也适用于生产环境。

链接:ERC20 - OpenZeppelin Docs

 类似资料: