receive fallback tips

当你调用一个智能合约中不存在的函数时,且同时存在receive()fallback()函数时,其行为取决于调用的上下文,特别是是否发送了以太币(ETH)以及调用是否包含数据。

  • 如果调用发送了ETH没有数据 ,那么将调用receive()函数。
  • 如果调用发送了ETH但包含数据 ,或者如果没有发送ETH,无论是否包含数据,都将调用fallback()函数。

例子

scss 复制代码
solidityCopy code
pragma solidity ^0.8.0;

contract Example {
    // 这个函数在收到纯ETH(无数据)时被调用
    receive() external payable { 
        // 处理接收ETH的逻辑
    }

    // 这个函数在调用了不存在的函数时被调用
    fallback() external payable { 
        // 处理其他逻辑
    }
}

在这个例子中:

  1. 如果你向Example合约发送ETH而不附带任何数据(例如,使用常规的以太坊转账),将调用receive()函数。
  2. 如果你尝试调用合约中不存在的函数(附带数据的调用)或发送ETH同时附带数据,则将调用fallback()函数。

总结

receive()fallback()的引入提供了对合约ETH接收的更好控制。receive()是在EIP-2309中引入的,目的是区分纯ETH接收和其他类型的调用。在实际编写和部署智能合约时,理解这些函数的行为非常重要,以确保合约按预期方式响应不同类型的调用和交易。

相关推荐
间彧36 分钟前
Kubernetes的Pod与Docker Compose中的服务在概念上有何异同?
后端
间彧39 分钟前
从开发到生产,如何将Docker Compose项目平滑迁移到Kubernetes?
后端
间彧1 小时前
如何结合CI/CD流水线自动选择正确的Docker Compose配置?
后端
间彧1 小时前
在多环境(开发、测试、生产)下,如何管理不同的Docker Compose配置?
后端
间彧1 小时前
如何为Docker Compose中的服务配置健康检查,确保服务真正可用?
后端
间彧1 小时前
Docker Compose和Kubernetes在编排服务时有哪些核心区别?
后端
间彧1 小时前
如何在实际项目中集成Arthas Tunnel Server实现Kubernetes集群的远程诊断?
后端
brzhang2 小时前
读懂 MiniMax Agent 的设计逻辑,然后我复刻了一个MiniMax Agent
前端·后端·架构
草明2 小时前
Go 的 IO 多路复用
开发语言·后端·golang
蓝-萧2 小时前
Plugin ‘mysql_native_password‘ is not loaded`
java·后端