< prev index next > src/java.base/share/classes/jdk/internal/misc/ThreadFlock.java
Print this page
/*
- * Copyright (c) 2021, 2023, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2021, 2024, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
/**
* Shutdown this flock so that no new threads can be started, existing threads
* in the flock will continue to run. This method is a no-op if the flock is
* already shutdown or closed.
- *
- * <p> This method may only be invoked by the flock owner or threads {@linkplain
- * #containsThread(Thread) contained} in the flock.
- *
- * @throws WrongThreadException if the current thread is not the owner or a thread
- * contained in the flock
*/
public void shutdown() {
- ensureOwnerOrContainsThread();
if (!shutdown) {
shutdown = true;
}
}
* {@linkplain #owner() owner} to return immediately.
*
* <p> If the owner is blocked in {@code awaitAll} then it will return immediately.
* If the owner is not blocked in {@code awaitAll} then its next call to wait
* will return immediately. The method does nothing when the flock is closed.
- *
- * @throws WrongThreadException if the current thread is not the owner or a thread
- * contained in the flock
*/
public void wakeup() {
- ensureOwnerOrContainsThread();
if (!getAndSetPermit(true) && Thread.currentThread() != owner()) {
LockSupport.unpark(owner());
}
}
< prev index next >