aspose file tools*
The moose likes Threads and Synchronization and the fly likes acquireInterruptibly => InterruptedException Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login
JavaRanch » Java Forums » Java » Threads and Synchronization
Bookmark "acquireInterruptibly => InterruptedException" Watch "acquireInterruptibly => InterruptedException" New topic
Author

acquireInterruptibly => InterruptedException

Jean-Michel Vilain
Greenhorn

Joined: Aug 06, 2010
Posts: 17

This exception:
java.lang.InterruptedException
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquireInterruptibly(AbstractQueuedSynchronizer.java:1219)
at java.util.concurrent.locks.ReentrantLock.lockInterruptibly(ReentrantLock.java:340)
at java.util.concurrent.ArrayBlockingQueue.put(ArrayBlockingQueue.java:321)
at faeria.world.action.WorldScheduler.schedule(WorldScheduler.java:78)
at faeria.game.core.FaeriaGame.run(FaeriaGame.java:131)
at java.lang.Thread.run(Thread.java:724)


My beautifully simple Scheduler's code:


Why? Happens very rarely... Where should I be looking for the cause?


Designer and developer on Faƫria: Strategy Card Game (www.faeria.net). The server is 100% Java.
@Jiem_ on Twitter (http://twitter.com/Jiem_)
Steve Luke
Bartender

Joined: Jan 28, 2003
Posts: 4174
    
  21

The thread which called the schedule method gets interrupted. We don't have any information about where schedule gets called, or what might be happening in and to that thread, so it is impossible for us to say. If you aren't sure of the sequence then start peppering your code with tons of log statements so you can see exactly the flow and what happens at or around the thread being interrupted.

edit: And remember: the interrupt doesn't have to happen while the put() operation is in progress, it just has to happen some time before the operation and not be cleared (using the Thread#interrupted() method, for example).


Steve
Jean-Michel Vilain
Greenhorn

Joined: Aug 06, 2010
Posts: 17

Thanks a lot for your clarifications Steve.
In my mind the put is almost instant so I found it very unlikely to have the thread interrupted right at this moment.
Helps a lot!!
 
I agree. Here's the link: http://aspose.com/file-tools
 
subject: acquireInterruptibly => InterruptedException