!7 static Lock a = fairLock(); static Lock b = fairLock(); p-tt { centerHigherConsole(); doEvery_daemon(1000, r { L lockingThreads = printDeadlocks(); if (nempty(lockingThreads)) { print("Interrupting locking threads."); L threads = threadInfosToThreads(lockingThreads); print("Interrupting " + n(threads, "thread")); for (Thread t : threads) t.interrupt(); } }); print("Initiating deadlock... :-)\n"); thread "A" { a.lock(); try { print("Thread A has lock A."); sleep1Second(); print("Thread A getting lock B."); b.lock(); try { print("Thread A successful!"); } finally { b.unlock(); } } finally { a.unlock(); } } thread "B" { b.lock(); try { print("Thread B has lock B."); sleep1Second(); print("Thread B getting lock A."); a.lock(); try { print("Thread B successful!"); } finally { a.unlock(); } } finally { b.unlock(); } } sleepQuietly(); }