Bird
Raised Fist0
Gitdevops~5 mins

Dropping and clearing stashes in Git - Time & Space Complexity

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: Dropping and clearing stashes
O(n) for git stash drop, O(1) for git stash clear
Understanding Time Complexity

We want to understand how the time to drop or clear stashes changes as the number of stashes grows.

How does git handle removing one or all stashes when there are many? Git stashes are stored in a reflog file for refs/stash.

Scenario Under Consideration

Analyze the time complexity of these git commands:

git stash drop stash@{2}
git stash clear

The first command removes a single stash by its index (rewriting reflog). The second removes all at once (deletes files).

Identify Repeating Operations

Look for repeated steps git must do internally.

  • Primary operation: Drop: read entire reflog file (~n lines) and rewrite omitting one entry. Clear: delete two files (refs/stash and logs/refs/stash).
  • How many times: Drop processes O(n) lines; clear is fixed file deletions.
How Execution Grows With Input

As the number of stashes (n) increases, the work changes like this:

Input Size (n)Approx. Operations for dropApprox. Operations for clear
10About 10 read/write operationsConstant: 2 file deletes
100About 100 read/write operationsConstant: 2 file deletes
1000About 1000 read/write operationsConstant: 2 file deletes

Pattern observation: Dropping one stash grows linearly (reflog rewrite), clearing all stays constant.

Final Time Complexity

Time Complexity: O(n) for git stash drop, O(1) for git stash clear

Drop rewrites the O(n)-sized reflog file; clear just deletes files instantly.

Common Mistake

[X] Wrong: "Drop is O(1) since it targets one; clear is O(n) iterating all."

[OK] Correct: Reflog is a file; drop rewrites whole file O(n), clear deletes files O(1).

Interview Connect

Explaining git internals and why operations scale certain ways demonstrates systems thinking and tool expertise.

Self-Check

"If git used a database or linked structure for reflogs, how might complexities change? Why file-based?"

Practice

(1/5)
1. What does the git stash drop command do?
easy
A. Removes a single stash entry from the stash list
B. Removes all stash entries at once
C. Creates a new stash entry
D. Shows the list of all stash entries

Solution

  1. Step 1: Understand the purpose of git stash drop

    This command is used to remove one specific stash entry from the stash list.
  2. Step 2: Differentiate from clearing all stashes

    git stash clear removes all stashes, not just one.
  3. Final Answer:

    Removes a single stash entry from the stash list -> Option A
  4. Quick Check:

    Drop = remove one stash [OK]
Hint: Drop removes one stash, clear removes all [OK]
Common Mistakes:
  • Confusing drop with clear
  • Thinking drop creates a stash
  • Assuming drop shows stash list
2. Which of the following is the correct syntax to clear all stashes in git?
easy
A. git stash drop --all
B. git stash delete --all
C. git stash clear
D. git stash remove all

Solution

  1. Step 1: Identify the command to clear all stashes

    The correct command to remove all stash entries is git stash clear.
  2. Step 2: Check other options for correctness

    Options A, B, and C are not valid git commands for clearing stashes.
  3. Final Answer:

    git stash clear -> Option C
  4. Quick Check:

    Clear = remove all stashes [OK]
Hint: Use 'git stash clear' to delete all stashes at once [OK]
Common Mistakes:
  • Using 'drop --all' which is invalid
  • Trying 'remove all' which is not a git command
  • Confusing delete with clear
3. Given the stash list:
stash@{0}: WIP on feature
stash@{1}: Fix bug
stash@{2}: Update docs

What will be the stash list after running git stash drop stash@{1}?
medium
A. stash@{0}: WIP on feature
stash@{1}: Fix bug
B. stash@{0}: WIP on feature
stash@{1}: Fix bug
stash@{2}: Update docs
C. stash@{0}: Fix bug
stash@{1}: Update docs
D. stash@{0}: WIP on feature
stash@{1}: Update docs

Solution

  1. Step 1: Understand what git stash drop stash@{1} does

    This command removes the stash at index 1, which is 'Fix bug'.
  2. Step 2: Recognize stash reindexing after drop

    After dropping stash@{1}, stash@{2} moves up to stash@{1} position.
  3. Final Answer:

    stash@{0}: WIP on feature
    stash@{1}: Update docs
    -> Option D
  4. Quick Check:

    Drop stash@{1} removes it and shifts others up [OK]
Hint: Dropped stash removed, higher indexes shift down [OK]
Common Mistakes:
  • Not realizing stash indexes shift after drop
  • Assuming stash@{1} remains after drop
  • Confusing stash names with indexes
4. You tried to remove all stashes using git stash drop without any arguments, but it did not remove all stashes. What is the likely cause?
medium
A. The command git stash drop clears all stashes by default
B. git stash drop without argument removes only the most recent stash (stash@{0}), not all
C. You need to run git stash clear before drop works
D. You must be on the master branch to drop stashes

Solution

  1. Step 1: Understand git stash drop usage

    This command removes one stash: stash@{0} (most recent) if no argument given, or a specific stash if referenced.
  2. Step 2: Identify why it doesn't remove all

    Without argument, it only drops the most recent stash, not all. To remove all, repeat or use git stash clear.
  3. Final Answer:

    git stash drop without argument removes only the most recent stash (stash@{0}), not all -> Option B
  4. Quick Check:

    Drop w/o arg = drop stash@{0} only [OK]
Hint: drop w/o arg removes latest only, clear removes all [OK]
Common Mistakes:
  • Assuming drop clears all stashes
  • Thinking drop without argument does nothing
  • Thinking branch affects stash drop
5. You have multiple stashes and want to remove all except the most recent one. Which sequence of commands achieves this safely?
hard
A. Run git stash drop stash@{1} repeatedly for all except stash@{0}
B. Run git stash clear then create a new stash for the most recent changes
C. Run git stash pop to apply and remove all stashes except the latest
D. Run git stash drop stash@{0} to remove the latest stash only

Solution

  1. Step 1: Understand stash indexing and removal

    Stashes are indexed from 0 (most recent) upwards. To keep the latest, remove others starting from index 1.
  2. Step 2: Use git stash drop stash@{1} repeatedly

    Dropping stash@{1} repeatedly removes older stashes safely without affecting the latest stash@{0}.
  3. Final Answer:

    Run git stash drop stash@{1} repeatedly for all except stash@{0} -> Option A
  4. Quick Check:

    Drop specific stashes to keep latest safe [OK]
Hint: Drop stashes from index 1 up to keep latest [OK]
Common Mistakes:
  • Using clear which deletes all stashes
  • Using pop which applies and removes only one stash
  • Dropping stash@{0} which removes the latest stash