Solidity——Using...For...基本用法

当编写智能合约时,可能会经常需要使用一些通用的功能,例如搜索数组中的元素或执行其他常见操作。Solidity编程语言提供了一种非常强大的机制,允许创建可重用的库函数并将它们附加到不同的数据类型上,以提高代码的可维护性和重用性。

一、什么是库函数?

库函数是一组可重用的函数,它们可以被附加到不同的数据类型上以提供常用功能。这使得您可以避免在每个合约中重复编写相同的代码,从而提高了代码的可读性和维护性。在Solidity中,库函数以库的形式存在,并且可以通过指令 using A for B 来附加到数据类型 B 上。

在声明库函数时,我们推荐使用 public 或 internal 修饰符。public 可以确保方法在其他合约和外部调用时可见,而 internal 可以确保方法只能在当前合约及其派生合约中访问。

二、案例

首先,我们创建一个简单的库合约,并定义一个库函数,用来作为查询一个数组中是否存在某个元素,如果存在则返回它在数组中的索引,否则返回-1:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.18;

library LibraryTest {

    ///pure表示该函数不会查询和修改合约状态变量,当然我们这里也没有定义状态变量
    ///External不适用于Library方法,external修饰符用于指定函数只能通过外部调用,但是library方法本身不能被外部合约调用,因此 xternal在library中没有实际意义
    ///Private限制了代码复用性,private修饰符将方法标记为私有的,只能在当前合约内部访问。使用private修饰符会限制代码的复用性,因为无法从其他合约中调用library的私有方法
    ///推荐使用public或internal修饰符。public可以确保方法在其他合约和外部调用时可见,而internal可以确保方法只能在当前合约及其派生合约中访问。
    function indexOf (uint[] memory arr,uint value) public pure returns(int){
        for (uint i = 0; i < arr.length; i++) {
            if (arr[i] == value) return int(i); 
        }
        return -1;
    }

}

然后,我们创建一个测试合约来应用上述库函数,在如下合约中,我们定义了一个数组,通过函数对它进行操作,其中查询数组中某个元素的索引位置,则用到了LibraryTest库中indexOf函数能力:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.18;

import "./LibraryTest.sol";//1在合约中引入库
contract UsingTest {
    using LibraryTest for uint[];//2将库赋能给合约数据类型
    uint[] public arr;

    ///往数组添加元素,由于函数数据对合约状态变量进行修改操作,所以函数状态必须可读可写
    function append(uint value) public {
        arr.push(value);
    }

    ///判断数字内是否存在某个元素,如果存在则替换成新元素,否则进行添加操作
    function replace(uint _old,uint _new) public {
        int index = arr.indexOf(_old);//3调用库函数能力
        if (index == -1) arr.push(_new);
        else arr[uint(index)] = _new;
    }
}

三、总结

使用库函数并将它们附加到数据类型上是Solidity中的强大特性之一,它可以大幅提高代码的可读性和可维护性。您可以创建通用的库函数,然后在多个合约中重复使用它们,而无需重复编写相同的代码,它是对合约代码进行抽象和封装设计的一种体现。这有助于减少错误并提高智能合约的安全性。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据区块链网络中心化程度的不同,分化出3种不同应用场景下的区块链:(1)全网公开,无用户授权机制的区块链,称为公有链;(2)允许授权的节点加入网络,可根据权限查看信息,往往被用于机构间的区块链,称为联盟链或行业链;(3)所有网络中的节点都掌握在一家机构手中,称为私有链。联盟链和私有链也统称为许可链,公有链称为非许可链。  公有区块链系统 公有链中,任何节点无须任何许可便可随时加入或脱离网络。从最早的比特币系统人手介绍公有链系统的发展现状。 点对点电子现金系统:比特币与传统分布式系统的C/S , B/S或三层架构不同,比特币系统基于P2P网络,所有节点对等,且都运行同样的节点程序。节点程序总体上分为两部分:一部分是前台程序,包括钱包或图形化界面;另一部分是后台程序,包括挖矿、区块链管理、脚本引擎及网络管理等。区块链管理:涉及初始区块链下载、连接区块、断开区块、校验区块和保存区块,以及发现最长链条的顶区块。内存池管理:即交易池管理。节点将通过验证的交易放在一个交易池中,并准备好将其放入下一步挖到的区块中。邻接点管理:当一个新比特币节点初始启动时,它需要发现网络中的其他节点,并与至少一个节点连接。共识管理:比特币中的共识管理包括挖矿、区块验证和交易验证规则。比特币采用PoW共识机制,依赖机器进行哈希运算来获取记账权,同时每次达成共识需要全网共同参与运算,允许全网50%节点出错。密码模块:比特币采用RIMEMD和SHA-256算法及Base-58编码生成比特币地址。签名模块:比特币采用椭圆曲线secp256k1及数字签名算法ECDSA来实现数字签名并生成公钥。脚本引擎:比特币的脚本语言是一种基于堆栈的编程脚本,共有256个指令,是非图灵完备的运算平台,没有能力计算任意带复杂功能的任务。本课程从零到一带领你实践一个小型公链。 智能合约,Smart Contract,是一种旨在以信息化方式传播、验证或执行合同的计算机协议。 区块链领域的智能合约有以下特点:规则公开透明,合约内的规则以及数据对外部可见;所有交易公开可见,不会存在任何虚假或者隐藏的交易。 所以我们常说区块链技术具有“公开透明”“不可篡改”的特点,这些其实都是智能合约赋予区块链的。 程序员的世界里一致有个认知:相较于程序和机器,人更加不可控。人会作恶,但是代码并不会主观主动作恶。 而传统的契约行为,都是由人来制定规则,由人去执行。当然,遇到边界问题或者异常,也是由人去做界定。 但有了智能合约之后,这些就变得不一样了。 开发者通过智能合约去制定一套规则,然后发布到线上,人与智能合约进行交互,由机器去完成业务的部分,这样就规避了由人来做执行时可能造成的作弊行为。 静态类型的编程语言——Solidity,是以太坊的智能合约实现的编程语言,运行在以太坊的虚拟机 Ethereum Virtual Machine(EVM)上。 借由 Solidity,开发人员能够编写出可自我执行的应用程序,该程式可被视为一份具权威性且永不可悔改的交易合约,对已具备程式编辑能力的人而言,编写 Solidity 的难易度就如同编写一般的编程语言。 关于智能合约的应用,大名鼎鼎的 ICO 就是其中之一。除了 ICO 之外,与物联网结合赋能智能家居、投票等等,都是智能合约的应用场景。换言之,能够用机器去实现既定的规则、提高效率,且能够规避人类的作弊行为的场景,基本都是智能合约的应用场景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tomggo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值