I am extremely confused as to why the following cast does not work:
ScheduledThreadPoolExecutor timeoutControl = (ScheduledThreadPoolExecutor) Executors.newSingleThreadScheduledExecutor();
ScheduledThreadPoolExecutor implements the ScheduledExecutorService. What's the point of this Executors call if I can't use it with an actual class.
Am I using it wrong (probably), could someone offer some guidance please?
The problem is that
Executors.newSingleThreadScheduledExecutor();
actually doesn't return aScheduledThreadPoolExecutor
.Source code in the
Executors
class:The
Delegated...
classes (there's aDelegatedExecutorService
too) are just passing all the calls to the underlying executor, theScheduledThreadPoolExecutor
in this case. The comments in the code suggest that the whole point of these classes is to hide all the non-interface methods that the underlying executor might have.In any case, it is better practice anyway to use the interface rather than the class version of the object you are working on (
List
and notArrayList
,ScheduledExecutorService
and notScheduledThreadPoolExecutor
).If you absolutely need functionality available in
ScheduledThreadPoolExecutor
and not in theScheduledExecutorService
, you could use the constructor ofScheduledThreadPoolExecutor
to create an instance of it.To simplify:
A class implementing an interface could have other methods and fields that the interface doesn't. In this case, the method returns the interface so you can't downcast this to the implementing class.
You should only use the returned executor as a
ScheduledExecutorService
, rather than casting it to aScheduledThreadPoolExecutor
.