Difficulty: Medium
Correct Answer: wait()
Explanation:
Introduction / Context:
Java threads change state based on specific primitives. Knowing which calls block the current thread is critical for correct synchronization.
Given Data / Assumptions:
wait().
Concept / Approach:wait() immediately causes the current thread to release the monitor and enter the WAITING (or TIMED_WAITING with timeout) state. In effect, it stops the current thread from executing until notified/timeout.
Step-by-Step Solution:
wait() → releases the monitor and suspends the thread.3) Later, a notify/notifyAll or timeout can move the thread to contend for the monitor again.
Verification / Alternative check:
By contrast, notify() and notifyAll() affect other waiting threads, not the calling thread.
Why Other Options Are Wrong:
notify(), notifyAll() → do not block the caller; they wake others.
Common Pitfalls:
Confusing wait() (blocking caller) with sleep() (also blocks caller but without monitor semantics) and with notify()/notifyAll() (do not block caller).
Final Answer:
wait()
Discussion & Comments