Unclear on close()

eric at kolotyluk.net eric at kolotyluk.net
Wed Jul 27 18:36:05 UTC 2022


Thanks for that clarity, Ron.

 

So, as always, use existing best practices to make sure that tasks and subtasks are robust in handling cancellation, interrupts, exceptions, etc.

 

Loom does not bring any new magic here…

 

Cheers, Eric

 

From: Ron Pressler <ron.pressler at oracle.com> 
Sent: July 27, 2022 10:17 AM
To: Eric Kolotyluk <eric at kolotyluk.net>
Cc: loom-dev at openjdk.java.net
Subject: Re: Unclear on close()

 

 





On 27 Jul 2022, at 17:35, eric at kolotyluk.net <mailto:eric at kolotyluk.net>  wrote:

 

1.	Is there any scenario where close() waits forever?

a.	Where it is implicit in this try block.
b.	I can imagine scenarios where subtasks don’t cancel properly or respond correctly to interrupts.

 

Yes, that could happen. It is a property of very general languages, like Java, and there’s no getting around it. It takes a very carefully-controlled language, like Erlang, to support the forceful (non-cooperative) termination of a thread, and even there things could go wrong unless some discipline is followed.

 

The core of the issue is that waiting for a thread to terminate is the least of your worries. It is more important to ensure that threads maintain your program’s logical invariants, and so we must ensure threads are terminated when they decide they’re ready. This requires their cooperation. So we can only ever *ask* for a thread to terminate; we can’t kill it in a way that safely maintains program invariants.

 

2.	If there is, is there any programmatic way out of this?

a.	Does the InterruptedException bypass close() and exit the try block?
b.	Is this guaranteed by the runtime?
c.	I assume it is, but I have made bad assumptions about the runtime before…

 

An exception could not bypass the close if used in a try-with-resources block, but because we rely on try-with-resources, which is optional (i.e. you could neglect to use the construct altogether), there are ways to write code that doesn’t call close. The runtime would, currently, only detect that if this interferes with other things that rely on correct nesting of scopes. So, e.g. if you don’t close a scope but then close an enclosing scope, that will be detected.





c.	 

4.	Personally, I would have thought that “scope.joinUntil(deadline);” would guarantee this code exits the try block, but the documentation, as written, does not give me that confidence. There are two wait points…

a.	scope.joinUntil(deadline);
b.	scope.close(); 

5.	While this may not be ambiguous to others, it is to me.

a.	It would be nice if there was text that made this more explicit.

 

Cheers, Eric

 

close can only return after all threads have terminated (except, maybe, due to a VM error). join/joinUntil wait for forks to: 1. terminate OR 2. be cancelled due to shutdown OR 3. until the waiting thread is interrupted or the timeout expires.

 

Whatever happens, close waits for all forked threads to fully terminate.

 

— Ron

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.org/pipermail/loom-dev/attachments/20220727/fe17bcf7/attachment-0001.htm>


More information about the loom-dev mailing list