Add workaround to let the sleep work correctly in windows too. See #356
This commit is contained in:
parent
2c7c67ef4c
commit
b994cde221
@ -32,6 +32,7 @@ import org.jboss.netty.channel.ChannelPipelineFactory;
|
|||||||
import org.jboss.netty.logging.InternalLogger;
|
import org.jboss.netty.logging.InternalLogger;
|
||||||
import org.jboss.netty.logging.InternalLoggerFactory;
|
import org.jboss.netty.logging.InternalLoggerFactory;
|
||||||
import org.jboss.netty.util.internal.ConcurrentIdentityHashMap;
|
import org.jboss.netty.util.internal.ConcurrentIdentityHashMap;
|
||||||
|
import org.jboss.netty.util.internal.DetectionUtil;
|
||||||
import org.jboss.netty.util.internal.ReusableIterator;
|
import org.jboss.netty.util.internal.ReusableIterator;
|
||||||
import org.jboss.netty.util.internal.SharedResourceMisuseDetector;
|
import org.jboss.netty.util.internal.SharedResourceMisuseDetector;
|
||||||
|
|
||||||
@ -445,11 +446,19 @@ public class HashedWheelTimer implements Timer {
|
|||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
final long currentTime = System.currentTimeMillis();
|
final long currentTime = System.currentTimeMillis();
|
||||||
final long sleepTime = tickDuration * tick - (currentTime - startTime);
|
long sleepTime = tickDuration * tick - (currentTime - startTime);
|
||||||
|
|
||||||
if (sleepTime <= 0) {
|
if (sleepTime <= 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
// Check if we run on windows, as if thats the case we will need
|
||||||
|
// to round the sleepTime as workaround for a bug that only affect
|
||||||
|
// the JVM if it runs on windows.
|
||||||
|
//
|
||||||
|
// See https://github.com/netty/netty/issues/356
|
||||||
|
if (DetectionUtil.isWindows()) {
|
||||||
|
sleepTime = (sleepTime / 10) * 10;
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Thread.sleep(sleepTime);
|
Thread.sleep(sleepTime);
|
||||||
|
@ -36,7 +36,21 @@ public final class DetectionUtil {
|
|||||||
|
|
||||||
private static final int JAVA_VERSION = javaVersion0();
|
private static final int JAVA_VERSION = javaVersion0();
|
||||||
private static final boolean HAS_UNSAFE = hasUnsafe(AtomicInteger.class.getClassLoader());
|
private static final boolean HAS_UNSAFE = hasUnsafe(AtomicInteger.class.getClassLoader());
|
||||||
|
private static final boolean IS_WINDOWS;
|
||||||
|
static {
|
||||||
|
String os = System.getProperty("os.name").toLowerCase();
|
||||||
|
// windows
|
||||||
|
IS_WINDOWS = os.indexOf("win") >= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return <code>true</code> if the JVM is running on Windows
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public static boolean isWindows() {
|
||||||
|
return IS_WINDOWS;
|
||||||
|
}
|
||||||
|
|
||||||
public static boolean hasUnsafe() {
|
public static boolean hasUnsafe() {
|
||||||
return HAS_UNSAFE;
|
return HAS_UNSAFE;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user