solidity函数篇
1.函数
函数是一组可重用的代码,可以在程序中的任何位置调用。 这消除了一次又一次编写相同代码的需要。 它可以帮助程序员编写模块化代码。 函数允许程序员将大程序划分为许多小的且可管理的函数。
与任何其他高级编程语言一样,Solidity 也支持使用函数编写模块化代码所需的所有功能。 本节介绍如何在 Solidity 中编写自己的函数。
1.函数定义
在使用函数之前,我们需要定义它。 在 Solidity 中定义函数的最常见方法是使用 function 关键字,后跟唯一的函数名称、参数列表(可能为空)和用大括号括起来的语句块 。
2.语法
此处显示了基本语法。
function function-name(parameter-list) scope returns() {//statements }
3.示例
尝试以下示例。 它定义了一个名为 getResult 的函数,该函数不带任何参数 −
pragma solidity ^0.5.0;contract Test {function getResult() public view returns(uint){uint a = 1; // local variableuint b = 2;uint result = a + b;return result;} }
4.函数参数
到目前为止,我们已经看到了不带参数的函数。 但是有一种方法可以在调用函数时传递不同的参数。 这些传递的参数可以在函数内部捕获,并且可以对这些参数进行任何操作。 一个函数可以接受多个参数,用逗号分隔。
5.调用函数
要在合约中稍后的某个位置调用函数,您只需编写该函数的名称,如以下代码所示。
尝试以下代码来了解字符串在 Solidity 中的工作原理。
pragma solidity ^0.5.0;contract SolidityTest { constructor() public{ }function getResult() public view returns(string memory){uint a = 1; uint b = 2;uint result = a + b;return integerToString(result); }function integerToString(uint _i) internal pure returns (string memory) {if (_i == 0) {return "0";}uint j = _i;uint len;while (j != 0) {len++;j /= 10;}bytes memory bstr = new bytes(len);uint k = len - 1;while (_i != 0) {bstr[k--] = byte(uint8(48 + _i % 10));_i /= 10;}return string(bstr);//access local variable} }
6.return 语句
Solidity 函数可以有一个可选的return 语句。 如果您想从函数返回值,则这是必需的。 该语句应该是函数中的最后一条语句。
如上面的示例,我们使用 uint2str 函数返回一个字符串。
在 Solidity 中,一个函数也可以返回多个值。 请参阅下面的示例 −
pragma solidity ^0.5.0;contract Test {function getResult() public view returns(uint product, uint sum){uint a = 1; // local variableuint b = 2;product = a * b;sum = a + b;//alternative return statement to return //multiple values//return(a*b, a+b);} }
2.函数修饰符
函数修饰符用于修改函数的行为。 例如,向函数添加先决条件。
首先我们创建一个带或不带参数的修饰符。
contract Owner {modifier onlyOwner {require(msg.sender == owner);_;}modifier costs(uint price) {if (msg.value >= price) {_;}} }
函数体插入特殊符号"_;"的位置 出现在修饰符的定义中。 因此,如果调用该函数时满足修饰符的条件,则执行该函数,否则抛出异常。
请参阅下面的示例 −
pragma solidity ^0.5.0;contract Owner {address owner;constructor() public {owner = msg.sender;}modifier onlyOwner {require(msg.sender == owner);_;}modifier costs(uint price) {if (msg.value >= price) {_;}} } contract Register is Owner {mapping (address => bool) registeredAddresses;uint price;constructor(uint initialPrice) public { price = initialPrice; }function register() public payable costs(price) {registeredAddresses[msg.sender] = true;}function changePrice(uint _price) public onlyOwner {price = _price;} }