RFR: 8322829: Refactor nioBlocker to avoid blocking while holding Thread's interrupt lock
Jaikiran Pai
jpai at openjdk.org
Fri Jan 5 17:37:24 UTC 2024
On Tue, 2 Jan 2024 10:21:11 GMT, Alan Bateman <alanb at openjdk.org> wrote:
> In preparation for when virtual threads can unmount while holding a monitor or unmount when blocking on monitorenter, the implementation of VirtualThread's interrupt method is refactored to avoid parking/blocking while holding the Thread's interrupt lock. The implementations of sun.nio.ch.Interruptible are refactored to close/wakeup the InterruptibleChannel/Selector after releasing the interrupt lock. There is a lot of test coverage for async close and interrupt, no additional tests are added.
src/java.base/share/classes/java/lang/VirtualThread.java line 863:
> 861: checkAccess();
> 862:
> 863: // if current thread is a virtual thread then prevent it from being
Is the use of "current thread" here meant to imply "Thread.currentThread()"? If so, is there a check missing for `Thread.currentThread().isVirtual()` here?
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/17219#discussion_r1443160966
More information about the nio-dev
mailing list