There\'s a desktop application that uses Thread.sleep() to achieve long (minutes or hours) delays. This same application has been working fine from Windows XP through (at l
This is expected, valid behavior. The documentation is very explicit, stating:
these sleep times are not guaranteed to be precise, because they are limited by the facilities provided by the underlying OS.
and:
In any case, you cannot assume that invoking
sleep
will suspend the thread for precisely the time period specified.
it's probably a bug in windows 10.. even os vital things done in metro like the start menu sometimes fail to wake up from suspended state in a timely fashion(depending of what all you have firewalled or disabled, unsurprisingly enough). I would have suggested checking the state of the thread/process with processhacker or some sysinternals tools and try to come up with some solution. then check with windows event logs and such.
or just do something silly like replace the sleep with a semaphore and sleep that gets executed in the command line.
the docs are pretty sure imho that it should wake up in a timely fashion, just that you shouldn't rely on it as an output timer on some datalines, playing music or such, but taking 100x the time is a little different.