Improve registering signal handlers in java.lang.Terminator.setup()

David Holmes david.holmes at oracle.com
Mon Aug 6 01:51:24 UTC 2012


Hi Frank,

On 3/08/2012 5:39 PM, Frank Ding wrote:
> Hi guys,
> I found that in java.lang.Terminator, setup() method,
> The following code of registering default signal handlers can be improved:
> / try {
> Signal.handle(new Signal("INT"), sh);
> Signal.handle(new Signal("TERM"), sh);
> } catch (IllegalArgumentException e) {
> }/
> The revised code is illustrated below:
> / try {
> Signal.handle(new Signal("INT"), sh);
> } catch (IllegalArgumentException e) {
> }
> try {
> Signal.handle(new Signal("TERM"), sh);
> } catch (IllegalArgumentException e) {
> }
> /The improved version makes more sense since exception thrown from first
> Signal.handle call does not affect subsequent calls. This is more
> consistent with its original intention.
> A patch I made is available @
> http://cr.openjdk.java.net/~youdwei/ojdk-430/webrev.00//
>
> /Could anybody please take a look at it? Thanks in advance/

Can you explain the context for this change. It seems to me that there 
is an expectation that the group of signals act homogenously: all or 
none, whereas your change make it appear that the success/failure for 
each signal is independent. Understanding exactly when/why the 
IllegalArgumentException is thrown is important here.

I don't like seeing the duplicated comment, perhaps that can be factored 
out to the head of the block of code?

Thanks,
David Holmes

> Best regards,
> Frank
> /



More information about the core-libs-dev mailing list