区块链笔记:智能合约高级特性: 事件、接口、函数修改器

本文主要是介绍区块链笔记:智能合约高级特性: 事件、接口、函数修改器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

事件

  • 在编程领域里面其实是很常用的一些做法
  • 事件是以太坊的日志功能: 当发生某个动作或者某个数据的条件变化的时候,可以来触发一个动作,这个触发的动作称之为事件
  • 设置的事件会被触发: 在以太坊智能合约的编程里面,可以通过event关键字来定义一个事件,举例:
    • event Deposit(address from, uint value);
    • 事件是没有方法体的, 使用的event关键字,有参数
    • 假如我们写了一个转账程序,事件是以太坊的日志功能,当合约某个方法被调用(这是一个动作),也就意味着某个数据发生了变化
    • 在以太坊中会记录这个日志,并抛出一个事件,外部的客户端程序可以监听被定义的事件
    • 比如:我们的钱包客户端可以监听存款转账事件,从而显示相应的提示消息或界面提示框
  • 外部可以监听事件的发生: 事件是在智能合约里面做了这样的一个定义,但是它的使用是要在外部区域使用的
    • 比如web3.js写的一个外部客户端程序
    • 在外部的客户端程序里面,我们来通过这个事件的一个监听调用来触发相应的外部的一些处理

接口

  • 接口和合约中的抽象方法非常类似,但也不同
    • 接口本身通过interface关键字定义
    • 接口不能再集成其他的合约
    • 接口中只放方法,不放属性变量且没有方法体
  • 所谓的接口就是一组可以面向外部的共同的调用方法
  • 对于外部程序来说,如果继承了这个接口,那么这个合约一定包含接口中的方法和实现
  • 用于代码封装,举例如下
pragma solidity ^0.4.19;interface Cash {function receive(address recipient, uint amount) external;function getRemain(address cashAccount) external;
}

函数修改器

  • 它的作用是 函数执行的修饰约束
  • 什么是修饰约束?
    • 当我们调用智能合约中的方法的时候,这个方法可能需要具备某个条件才能被执行
    • 下面是个具体的例子
pragma solidity ^0.4.19;contract FunctionModifierTest {// 这里有一个构造方法,把调用者的地址(合约部署者的地址)// 构造方法会在合约部署的时候会被执行一次,把部署者的账户地址存在myself变量里function FunctionModifierTest() public {myself = msg.sender;}address myself;bool frozen;// 使用modifier声明一个函数修改器// 函数修改器类似方法一样,可以这样声明定义// 函数当前调用地址如果不是部署者则会报异常// 函数修改器类似一种语法糖,封装了一些条件判断而已// 如果不使用函数修改器,则需要加一些判断,函数修改器让代码更加简洁modifier onlyOwner {assert(msg.sender != myself);_;}// 当我们调用另一个方法close关闭合约,将合约中的frozen属性变量编程true表示关闭// 任何调用者都可以关闭肯定是不行的,我们需要对这个方法做一个约束,用了上面onlyOwner的函数修改器function close() public onlyOwner {frozen = true;}
}

这篇关于区块链笔记:智能合约高级特性: 事件、接口、函数修改器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/950961

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Java中的for循环高级用法

《Java中的for循环高级用法》本文系统解析Java中传统、增强型for循环、StreamAPI及并行流的实现原理与性能差异,并通过大量代码示例展示实际开发中的最佳实践,感兴趣的朋友一起看看吧... 目录前言一、基础篇:传统for循环1.1 标准语法结构1.2 典型应用场景二、进阶篇:增强型for循环2.

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编