Bird
Raised Fist0
Blockchain / Solidityprogramming~5 mins

Why gas efficiency saves money in Blockchain / Solidity - Performance Analysis

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Time Complexity: Why gas efficiency saves money
O(n)
Understanding Time Complexity

When working with blockchain, every operation costs gas, which means money. Understanding how the number of operations grows helps us see why saving gas is important.

We want to know how the cost changes as the work done by a smart contract increases.

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


function batchTransfer(address[] memory recipients, uint256 amount) public {
  for (uint i = 0; i < recipients.length; i++) {
    transfer(recipients[i], amount);
  }
}
    

This function sends tokens to many addresses by looping through each recipient and transferring tokens.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: The for-loop that calls transfer for each recipient.
  • How many times: Once for every address in the recipients list.
How Execution Grows With Input

As the number of recipients grows, the number of transfers grows the same way.

Input Size (n)Approx. Operations
1010 transfers
100100 transfers
10001000 transfers

Pattern observation: The work grows directly with the number of recipients. Double the recipients, double the work.

Final Time Complexity

Time Complexity: O(n)

This means the cost grows in a straight line with the number of recipients. More recipients mean more gas spent.

Common Mistake

[X] Wrong: "Adding more recipients won't increase gas cost much because transfers are simple."

[OK] Correct: Each transfer uses gas, so more recipients mean more transfers and more gas. The cost adds up directly.

Interview Connect

Understanding how gas cost grows with input size shows you can write smart contracts that save money. This skill helps you build better blockchain apps and impress interviewers with practical knowledge.

Self-Check

"What if we replaced the loop with a single batch transfer call that handles all recipients at once? How would the time complexity change?"

Practice

(1/5)
1. Why does gas efficiency matter when writing blockchain smart contracts?
easy
A. Because it makes the code run faster on a regular computer
B. Because it increases the size of the blockchain
C. Because it reduces the transaction cost paid in cryptocurrency
D. Because it allows unlimited transactions without fees

Solution

  1. Step 1: Understand what gas represents in blockchain

    Gas is a fee paid to execute operations on the blockchain, measured in cryptocurrency.
  2. Step 2: Connect gas efficiency to cost savings

    Using less gas means paying less cryptocurrency for the same operation.
  3. Final Answer:

    Because it reduces the transaction cost paid in cryptocurrency -> Option C
  4. Quick Check:

    Gas efficiency = lower transaction cost [OK]
Hint: Gas means fee; less gas means less money spent [OK]
Common Mistakes:
  • Confusing gas with code speed on a computer
  • Thinking gas increases blockchain size
  • Believing gas allows free transactions
2. Which of the following Solidity code snippets is more gas efficient?
easy
A. Using for loops with large fixed ranges
B. Using string for storing numbers
C. Using multiple require statements instead of one
D. Using uint8 instead of uint256 for small numbers

Solution

  1. Step 1: Identify data types and their gas costs

    Smaller data types like uint8 use less storage and gas than larger types like uint256.
  2. Step 2: Compare options for gas efficiency

    Using uint8 for small numbers saves gas compared to storing numbers as strings or using inefficient loops.
  3. Final Answer:

    Using uint8 instead of uint256 for small numbers -> Option D
  4. Quick Check:

    Smaller data types = less gas [OK]
Hint: Use smallest suitable data type to save gas [OK]
Common Mistakes:
  • Using strings to store numbers wastes gas
  • Multiple require statements add unnecessary gas
  • Large loops increase gas cost
3. Consider this Solidity function:
function add(uint256 a, uint256 b) public pure returns (uint256) {
    uint256 c = a + b;
    return c;
}

If you replace uint256 with uint8 for variables a, b, and c, what is the main effect on gas usage?
medium
A. Gas usage will decrease because smaller types use less storage
B. Gas usage will increase because smaller types are slower
C. Gas usage will stay the same because addition cost is fixed
D. Gas usage will cause an error due to overflow

Solution

  1. Step 1: Understand gas cost of data types

    Smaller data types like uint8 use less gas for storage and operations than uint256.
  2. Step 2: Consider the effect on gas usage

    Replacing uint256 with uint8 reduces gas because less storage and computation is needed.
  3. Final Answer:

    Gas usage will decrease because smaller types use less storage -> Option A
  4. Quick Check:

    Smaller type = less gas [OK]
Hint: Smaller integer types reduce gas cost [OK]
Common Mistakes:
  • Assuming smaller types slow down code
  • Ignoring gas savings from smaller storage
  • Confusing overflow errors with gas usage
4. This Solidity function is intended to save gas by using uint8 but causes an error:
function multiply(uint8 a, uint8 b) public pure returns (uint8) {
    uint8 result = a * b;
    require(result >= a, "Overflow");
    return result;
}

What is the main problem causing the error?
medium
A. Using uint8 causes syntax errors
B. The require condition does not correctly detect overflow
C. Multiplication is not allowed on uint8
D. The function should return uint256 instead

Solution

  1. Step 1: Analyze the overflow check logic

    The condition result >= a is not a reliable way to detect overflow in multiplication.
  2. Step 2: Understand why this causes errors

    If overflow occurs, the check might pass incorrectly or fail, causing unexpected errors.
  3. Final Answer:

    The require condition does not correctly detect overflow -> Option B
  4. Quick Check:

    Incorrect overflow check causes errors [OK]
Hint: Use safe math libraries for overflow checks [OK]
Common Mistakes:
  • Assuming uint8 causes syntax errors
  • Believing multiplication is disallowed on uint8
  • Ignoring overflow risks in small types
5. You want to optimize a smart contract function that stores user balances. Which approach saves the most gas and money?
hard
A. Use mapping(address => uint8) if balances never exceed 255
B. Store balances as strings to allow flexible formatting
C. Store balances as uint256 and update them frequently
D. Use arrays to store balances and loop through them on each update

Solution

  1. Step 1: Identify the best data structure and type for gas efficiency

    Using a mapping with uint8 saves gas by using less storage and avoiding loops.
  2. Step 2: Compare other options for gas cost

    Using uint256 wastes storage if values are small; strings and arrays increase gas due to size and looping.
  3. Final Answer:

    Use mapping(address => uint8) if balances never exceed 255 -> Option A
  4. Quick Check:

    Smaller types + mappings = gas savings [OK]
Hint: Use smallest type and mappings to save gas [OK]
Common Mistakes:
  • Using large types unnecessarily wastes gas
  • Storing numbers as strings is inefficient
  • Looping over arrays increases gas cost