如何修复browser / IERC20.sol:4:53:警告:此声明会影响现有声明

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何修复browser / IERC20.sol:4:53:警告:此声明会影响现有声明相关的知识,希望对你有一定的参考价值。

错误:

browser / IERC20.sol:4:53:警告:此声明会影响现有声明。 function totalSupply()public constant returns(uint256 totalSupply);

browser / IERC20.sol:4:5:阴影声明在这里:function totalSupply()public constant returns(uint256 totalSupply);

IERC20.sol

pragma solidity ^0.4.17;
interface IERC20 {
function totalSupply() public constant returns (uint256 totalSupply);
function balanceOf(address _owner) public constant returns (uint256 balance);
function transfer(address _to, uint256 _value) public returns (bool success);
function transferFrom(address _from, address _to, uint256 _value) public returns (bool success);
function approve(address _spender, uint256 _value) public returns (bool success);
function allowance(address _owner, address _spender) public constant returns (uint256 remaining);
event Transfer(address indexed _from, address indexed _to, uint256 _value);
event Approval(address indexed _owner, address indexed _spender, uint256 _value);
}

ındtoken.sol

pragma solidity ^0.4.11;

import './IERC20.sol';

contract INDToken is IERC20 {

    uint public constant _totalSupply = 1000000;

    string public constant symbol = "IND";
    string public constant name = "Indonesia Token";
    uint8 public constant decimals = 3;

    mapping(address => uint256) balances;
    mapping(address => mapping(address => uint256)) allowed;

    function INDToken() public {
        balances[msg.sender] = _totalSupply;
    }

    function totalSupply() public constant returns (uint256 totalSupply){
        return _totalSupply;
    }

    function balanceOf(address _owner) public constant returns (uint256 balance){
        return balances[_owner];
    }

    function transfer(address _to, uint256 _value) public returns (bool success){
        require(
            balances[msg.sender] >= _value
            && _value > 0
        );
        balances[msg.sender] -= _value;
        balances[_to] += _value;
        Transfer(msg.sender, _to, _value);
        return true;
    }

    function transferFrom(address _from, address _to, uint256 _value) public returns (bool success){
        require(
            allowed[_from][msg.sender] >= _value
            && balances[_from] >= _value
            && _value > 0
        );
        balances[_from] -= _value;
        balances[_to] += _value;
        allowed[_from][msg.sender] -= _value;
        Transfer(_from, _to, _value);
        return true;
    }

    function approve(address _spender, uint256 _value) public returns (bool success) {
        allowed[msg.sender][_spender] = _value;
        Approval(msg.sender, _spender, _value);
        return true;
    }

    function allowance(address _owner, address _spender) public constant returns (uint256 remaining){
        return allowed[_owner][_spender];
    }

    event Transfer(address indexed _from, address indexed _to, uint256 _value);
    event Approval(address indexed _owner, address indexed _spender, uint256 _value);
}
答案

我认为问题是重用函数名作为返回值名称。我只想删除返回值的名称,因为你还没有使用它:

function totalSupply() public constant returns (uint256) {

作为替代方案,您可以将其命名为不同的东西:

function totalSupply() public constant returns (uint256 total) {

以上是关于如何修复browser / IERC20.sol:4:53:警告:此声明会影响现有声明的主要内容,如果未能解决你的问题,请参考以下文章

第131篇 ERC20 锁仓合约

myeclipse web browser 出现 http400 而其他浏览器可以打开

html view in browser为啥空白

SoapUI在macOS下启动卡死问题处理

cefsharp做的客户端如何实现文件下载

代币标准--ERC1155协议源码解析