In Solidity, one of the fundamental aspects of writing smart contracts is handling Ethereum addresses. Ethereum addresses are pivotal in transactions, storing funds, and interacting with other smart contracts. In Solidity, there are two types of address types you need to be familiar with: address and address payable.
Source Code: https://github.com/scaihai/enkwadore-blog-blockchain-demos/tree/main/solidity/contracts/3.1.2
What is an address?
An address in Solidity is a 20-byte value that uniquely identifies a contract or an account on the Ethereum blockchain. It is a fundamental data type used to store and manage Ethereum addresses.
address myAddress = 0x1234567890abcdef1234567890abcdef12345678;Key Characteristics:
- It can hold the address of a user, smart contract, or external account.
- It provides several methods, such as balanceto check the ether balance.
- It’s typically used when you don’t need to send Ether.
Common Methods:
- balance: Returns the balance of the address in wei.
- code.length: Returns the length of the code at the address. If the address is a smart contract, code.length will be greater than 0.
Example Usage:
Example.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract Example {
    address public owner;
    constructor() {
        owner = msg.sender; // Sets the owner to the address that deployed the contract
    }
    function getOwnerBalance() public view returns (uint) {
        return owner.balance; // Returns the balance of the owner
    }
}What is address payable?
address payable is a special type of address that can send and receive Ether. The distinction is crucial when you’re writing functions that involve transferring Ether.
address payable myPayableAddress = payable(0x1234567890abcdef1234567890abcdef12345678);Key Characteristics:
- It can hold and send Ether.
- It includes additional methods to facilitate Ether transfers, such as transferandsend.
Common Methods:
- transfer(uint amount): Sends the specified amount of wei to the address and reverts on failure.
- send(uint amount): Sends the specified amount of wei to the address and returns a boolean indicating success.
Example Usage:
PayableExample.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract PayableExample {
    address payable public recipient;
    constructor(address payable _recipient) {
        recipient = _recipient; // Sets the recipient address
    }
    function sendEther() public payable {
        require(msg.value > 0, "Send some ether");
        recipient.transfer(msg.value); // Transfers the received Ether to the recipient
    }
    function getRecipientBalance() public view returns (uint) {
        return recipient.balance; // Returns the balance of the recipient
    }
}Converting address to address payable
Sometimes you may need to convert an address to an address payable. This can be done using the payable keyword.
address myAddress = 0x1234567890abcdef1234567890abcdef12345678;
address payable myPayableAddress = payable(myAddress);
Practical Considerations
- Security: Always validate the addresses before interacting with them, especially when transferring Ether.
- Gas Efficiency: Be mindful of gas costs when transferring Ether using transferorsend. Usecallwith caution as it forwards all remaining gas but handles errors differently.
Conclusion
Understanding address and address payable is essential for writing robust and secure smart contracts. While address is suitable for non-payable functions and interactions, address payable should be used whenever Ether transfers are involved. This distinction ensures that your contracts can handle funds appropriately and securely.
 
