【区块链-智能合约工程师】第三篇:Solidity进阶(一)

这篇具有很好参考价值的文章主要介绍了【区块链-智能合约工程师】第三篇:Solidity进阶(一)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

学习资料地址:WTF学院

合约库

库合约一般都是一些好用的函数合集(库函数),为了提升solidity代码的复用性和减少gas而存在。他和普通合约主要有以下几点不同:

  • 不能存在状态变量
  • 不能够继承或被继承
  • 不能接收以太币
  • 不可以被销毁
String库

String库合约是将uint256(大正整数)类型转换为相应的string类型的代码库,主要包含两个函数,toString()将uint256转为string,toHexString()将uint256转换为16进制,再转换为string。

library Strings {
	function toString(uint256 value) public pure returns (string memory) {}
	
	function toHexString(uint256 value) public pure returns (string memory) {}
	
	function toHexString(uint256 value, uint256 length) public pure returns (string memory) {}
}
调用库函数

使用 using A for B; 语句:添加完指令后,A 库的函数会自动添加为 B 类型变量的函数成员,可以直接调用。(在调用时,B变量会被当作第一个参数传递给函数)

    // 利用using for指令
    using Strings for uint256;
    function getString1(uint256 myNumber) public pure returns(string memory){
        // 库函数会自动添加为uint256型变量的成员
        return myNumber.toHexString();
    }

通过库合约名称调用库函数:

    // 直接通过库合约名调用
    function getString2(uint256 myNumber) public pure returns(string memory){
        return Strings.toHexString(myNumber);
    }
常用的合约库
合约库 说明
String 将uint256转换为String
Address 判断某个地址是否为合约地址
Create2 更安全的使用Create2 EVM opcode
Arrays 跟数组相关的库函数

import

solidity支持利用import关键字导入其他源代码中的合约,让开发更加模块化。

  1. 通过相对路径/绝对路径:import ‘./Yeye.sol’;
  2. 通过源文件网址导入网上的合约:import ‘https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/utils/Address.sol’;
  3. 通过npm的目录导入:import ‘@openzeppelin/contracts/access/Ownable.sol’;
  4. 通过全局符号导入特定的合约:import {Yeye} from ‘./Yeye.sol’;

引用(import)在代码中的位置为:在声明版本号之后,在其余代码之前。

问题:与声明版本号并列,还是在合约里导入?
回答:与声明版本号并列。

接收ETH

Solidity支持两种特殊的回调函数,receive()和fallback(),他们主要在两种情况下被使用:

  • 接收ETH
  • 处理合约中不存在的函数调用(代理合约proxy contract)
接收函数 receive()

receive() 函数只用于处理接收ETH,一个合约最多有一个receive()函数,声明方式与一般函数不一样,不需要function关键字。

声明规则:receive()函数不能有任何的参数,不能返回任何值,必须包含external和payable。

receive() external payable { ... }

我们可以在receive()里发送一个event:

    // 定义事件
    event Received(address Sender, uint Value);
    // 接收ETH时释放Received事件
    receive() external payable {
        emit Received(msg.sender, msg.value);
    }
回退函数 fallback()

fallback()声明时不需要function关键字,必须由external修饰,一般也会用payable修饰,用于接收ETH:

fallback() external payable { ... }

定义一个fallback()函数,被触发时候会释放fallbackCalled事件,并输出msg.sender,msg.value和msg.data:

    // fallback
    fallback() external payable{
        emit fallbackCalled(msg.sender, msg.value, msg.data);
    }
二者的区别

receive和fallback都能够用于接收ETH,他们触发的规则如下,简单说就是:只有msg.data为空且存在receive()时,才会触发receive()文章来源地址https://www.toymoban.com/news/detail-736674.html

触发fallback() 还是 receive()?
           接收ETH
              |
         msg.data是空?
            /  \
          是    否
          /      \
receive()存在?   fallback()
        / \
       是  否
      /     \
receive()   fallback()

到了这里,关于【区块链-智能合约工程师】第三篇:Solidity进阶(一)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 区块链2——Solidity智能合约开发

    区块链 索引目录 智能合约是一种以代码形式编写的自动执行合约,它们运行在区块链上。这些合约定义了在特定条件下发生的事件以及相应的行为。 1.1 智能合约结构 版本声明(Version Declaration): 智能合约通常以声明版本开始,指定合约应该使用的Solidity编译器版本。例如

    2024年02月05日
    浏览(45)
  • 区块链智能合约编程语言 Solidity

    上文介绍了区块链生态发展,我们知道以太坊的到来可以使开发人员基于区块链开发DApp,本文介绍 Solidity 编程语言的使用,然后基于 Solidity 编写一个简单的智能合约。 Solidity 是以太坊开发人员使用的编程语言,用来编写智能合约,运行在以太坊虚拟机(EVM)上。 有开发经

    2024年02月12日
    浏览(40)
  • 数据库系统工程师——第三章 数据结构与算法

    数据结构是指 数据元素的集合 及 元素间的相互关系和构造方法 ,结构就是元素之间的关系。在数据结构中,元素之间的相互关系是数据的逻辑结构。按照逻辑关系的不同将数据结构分为线性结构和非线性结构,其中,线性结构包括线性表、栈、队列、串,非线性结构主要包

    2024年02月04日
    浏览(52)
  • 【区块链实战】Solidity 智能合约如何给账户充值

    目录 一、实战场景 二、知识点 智能合约 智能合约函数 智能合约充值 payable 智能合约部署地址 智能合约的运行 合约 this 对象 三、菜鸟实战 四、运行结果 Solidity 智能合约如何给账户充值 1、充值金额 2、充值并查看结果

    2024年02月09日
    浏览(37)
  • 陪伴成长|区块链工程师能力认证项目启动BSV奖励计划

    由可一科技与CSDN联合运营的BSV区块链开发工程师能力认证项目于2022年6月6日发布了首门正式课程《区块链原理初级》,并于6月27日正式启动了区块链工程师能力初级认证。 为鼓励广大区块链爱好者积极学习课程、奖励优秀学员,今天我们正式推出“陪伴成长•BSV奖励计划”

    2024年02月16日
    浏览(45)
  • 区块链智能合约solidity的中的一些关键字

    目  录 pragma mapping msg对象 block对象 contract constructor struct 数据地址 地址类型 address payable revert 以下场景使用 revert() : require 以下场景使用 require() : assert 以下场景使用 assert(): 访问权限 internal public private external function returns return view pure constant event emit modifier pragma   

    2024年01月16日
    浏览(60)
  • 云计算工程师系列 Day03 第三章 权限管理(超详细 持续更新中....)

    简介:本章讲述了Linux系统CentOS7中关于权限的相关概念。以及用户和组的管理方法。 目标:熟悉并掌握权限的相关概念,以及用户和组的管理方法。 (1)概述 赋于某个用户或组能够以何种方式访问某个文件(图片文件,视频文件,普通文件) (2)权限对象 01.属主(u):一般是

    2024年01月21日
    浏览(48)
  • 区块链web3智能合约Solidity学习资源整理

    Solidity 是一门面向合约的、为实现智能合约而创建的高级编程语言。这门语言受到了 C++,Python 和 Javascript 语言的影响,设计的目的是能在以太坊虚拟机(EVM)上运行。 Solidity中文官方文档: https://solidity-cn.readthedocs.io/zh/develop/ https://learnblockchain.cn/docs/solidity/index.html 在线rem

    2024年03月19日
    浏览(50)
  • 小白到运维工程师自学之路 第三十九集 (HAproxy 负载均衡) 一、概述

            HAProxy是一款高性能的负载均衡软件,可以将来自客户端的请求分发到多个服务器上,以提高系统的可用性和性能。HAProxy支持多种负载均衡算法,包括轮询、加权轮询、最少连接数等。同时,HAProxy还支持会话保持、健康检查、SSL终止等功能,可以满足不同场景下的

    2024年02月09日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包