当前位置: 首页 > news >正文

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;}
}
http://www.xdnf.cn/news/1465777.html

相关文章:

  • 5分钟征服Linux:20个神级命令+系统架构解密,让命令行恐惧症瞬间治愈!
  • 智能风险评估与欺诈检测系统
  • 普通键盘在MacOS上如何使用快捷键
  • 分布式常见面试题整理
  • k8s 部署 redis
  • springboot redis 缓存入门与实战
  • [bat-cli] 输出处理 | `OutputType` 和 `OutputHandle`
  • 基于华为云平台的STM32F103C8T6工业生产线温湿度监控系统
  • 深度学习书籍推荐
  • LangChain: Models, Prompts 模型和提示词
  • UE4 Mac构建编译报错 no member named “disjunction” in namespace “std”
  • 企业为何仍困在“数据孤岛”?——从iPaaS重构信息流的实践路径
  • 一个专为地图制图和数据可视化设计的在线配色网站,可以助你制作漂亮的地图!
  • Leetcode—2749. 得到整数零需要执行的最少操作数【中等】(__builtin_popcountl)
  • 嵌入式系统学习Day31(多路IO复用)
  • Android Studio新版本编译release版本apk实现
  • 在Ubuntu 20.04的服务器上查找的服务器的IP地址
  • 2025最全的软件测试面试八股文(含答案+文档)
  • 属性关键字
  • Kubernetes(k8s) po 配置持久化挂载(nfs)
  • Ansible 角色使用指南
  • js设计模式-状态模式
  • 腾讯最新开源HunyuanVideo-Foley本地部署教程:端到端TV2A框架,REPA策略+MMDiT架构,重新定义视频音效新SOTA!
  • 2025精选5款AI视频转文字工具,高效转录秒变文字!
  • MySQL集群——主从复制
  • MongoDB 源码编译与调试:深入理解存储引擎设计
  • solidity的高阶语法
  • 【Linux】网络安全管理:SELinux 和 防火墙联合使用 | Redhat
  • 红黑树 + 双链表最小调度器原型
  • 【JMeter】分布式集群压测