记录智能合约solidity编译的坑

在Linux环境下入门写一段solidity编译遇到error和warning,经过一番研究后才得其缘由,下面以一段demo总结一下。

pragma solidity ^0.5.2;        // 指定所需的编译器版本

contract clac{                 
        function multiply(uint a, uint b) returns (uint){
                return a + b;
        }
}

看似很正常的一段两数相加代码,可惜编译出错:

出现了一段error和一段warning

$ solc --bin testContract.sol

testContract.sol:3:2: Error: No visibility specified. Did you intend to add "public"?
    function multiply(uint a, uint b) returns (uint)
 ^ (Relevant source part starts here and spans across multiple lines).

testContract.sol:5:9: Warning: Function state mutability can be restricted to pure
function multiply(uint a, uint b) public returns (uint) {
^ (Relevant source part starts here and spans across multiple lines).

原因是public声明和puer没有处理好。

public声明

No visibility specified. Defaulting to “public”。   -> 未指定可见性,采用默认public可见范围。

  • public:智能合约外部和内部都可使用的方法;
  • internal:智能合约(包括派生合约)内部可用调用的方法;
  • external:可通过其他合约和交易进行调用的方法;
  • private:只有在定义的合约中才可以调用,即使派生的合约也无法调用;

错误在于提醒开发者,你未指定当前function的可见范围,合约会默认采用public,有一定的风险存在。特别针对一些不可对外公开访问的智能合约,需要注意此提示。消除此警告的方法只需在方法中添加public声明即可。修改之后的代码如下:

pragma solidity ^0.5.2;        // 指定所需的编译器版本

contract clac{                 
        function multiply(uint a, uint b) public returns (uint){
                return a + b;
        }
}

 

pure限制词

Function state mutability can be restricted to pure。 -> 功能状态可变性可以限制为pure

在之前的版本中我们经常使用constant来限制一个方法的制度性,当用constant修饰之后,此方法在被调用时不会进行存储的变更,同样不会产生交易和gas花费。而pure正是constant的替代品,逐渐的在替代constant的功能。

修改后代码如下:

pragma solidity ^0.5.2;        // 指定所需的编译器版本

contract clac{                 
        function multiply(uint a, uint b) public pure returns (uint){
                return a + b;
        }
}

猜你喜欢

转载自www.cnblogs.com/kumata/p/10638619.html