如何解决BEP20 如何从 maxlimit 函数中排除烧录钱包
我正在尝试创建一个项目并且是 solidity 的新手。 我添加了一个最大限制来防止鲸鱼钱包。 限制是 150m 代币,我想烧掉更多的代币,我如何从这个函数中排除烧录地址 0x0000000000000000000000000000000000000000。
代码:
@ function _transfer(
uint256 contractBalanceRecepient = balanceOf(to);
require(contractBalanceRecepient + amount <= _maxWalletToken,"Exceeds maximum wallet token amount (150,000,000)");
亲切的问候凯文!
解决方法
您可以扩展 require()
中的条件,使其仅适用于非 0x0 的地址。
require(
(
contractBalanceRecepient + amount <= _maxWalletToken
&& to != address(0x0)
),"Exceeds maximum wallet token amount (150,000,000)"
);
注意:大多数销毁实现不会将代币转移到 0x0
。相反,他们只是降低总供应量,降低发件人余额并发出 Transfer()
事件,就好像他们正在转移到 0x0 一样 - 没有执行实际转移......但是你的方式(实际转移到 0x0)是可能的嗯。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。