The receive Function

A contract in Solidity can only have one receive function, which is declared using the receive keyword (without the function keyword). The receive function within a contract serves a specific purpose and is crucial in handling Ether transfers. This function can’t take parameters, can’t return anything, and must be externally visible and mutable in its payable state. It can be virtual, overrideable, and modifiable.

Characteristics of the receive function

  • No parameters or return values: The receive function accepts no parameters and returns no value; it’s only intended to receive Ether.

  • External and payable: The receive function must be external payable. The external visibility modification enables the function to be invoked from outside the contract, and the payable modifier indicates that it can receive Ether.

  • No overloading: The receive function, unlike conventional functions, can’t be overloaded with different argument types. A contract can only have one receive function.

  • Implicit invocation: When the contract receives a simple Ether transfer (via the .send() or .transfer() function calls), the receive function is implicitly invoked. When no function with a matching calldata is supplied in the transaction, it’s called automatically.

Purpose of the receive function

The receive function’s principal job is to handle standard Ether transfers to a contract. When a user provides Ether to a contract without specifying a function to call, the receive function is the point at which Ether is processed. When Ether is given to the contract, it’s often used for accepting payments, managing Ether balances, and executing basic tasks.

Gas limitations in the receive function

The amount of gas available for execution is a critical limitation of the receive function. The receive function can rely on just 2,300 gas in the worst-case situation (equivalent to using the .send() or .transfer() function calls). This gas stipend is quite restricted and only allows for rudimentary operations. The following operations require more gas than the stipend of 2,300:

  • Adding additional storage: Writing to storage is gas-intensive and exceeds the gas stipend.

  • Creating a new contract: Deploying a new contract consumes significantly more gas than the available stipend.

  • Invoking an external function: Calling an external function that consumes substantial gas, such as a complex computation or an external contract with high gas costs, might result in running out of gas.

  • Transferring Ether: Initiating a further Ether transfer from the receive function consumes additional gas.

Get hands-on with 1400+ tech skills courses.