8025619: (fc) FileInputStream.getChannel on closed stream returns FileChannel that doesn't know that stream is closed

Brian Burkhalter brian.burkhalter at oracle.com
Mon Dec 8 22:28:17 UTC 2014


On Dec 6, 2014, at 3:46 AM, Alan Bateman <Alan.Bateman at oracle.com> wrote:

> On 05/12/2014 22:06, Brian Burkhalter wrote:
>> :
>> 
>> Here’s an updated patch which extends Alan’s suggested patch:
>> 
>> http://cr.openjdk.java.net/~bpb/8025619/webrev.01/
>> 
> 
> I think you need to make channel volatile, this also means you can change getChannel() to use the double-checked locking idiom.
> 
> You can make closed final.
> 
> The changes to FileKey aren't strictly required but shouldn't be an issue.
> 
> I think the test should assert that the channel is closed. There isn't anything special with tryLock but if you want to attempt a few operations to checking that ClosedChannelException is thrown then that would be good.

Here’s an updated patch incorporating the foregoing suggested changes:

http://cr.openjdk.java.net/~bpb/8025619/webrev.02/

Thanks,

Brian
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.openjdk.java.net/pipermail/nio-dev/attachments/20141208/4cf05b0e/attachment.html>


More information about the nio-dev mailing list