Allow to set IoRatio to 100%

This commit is contained in:
Norman Maurer 2014-02-12 15:22:39 +01:00
parent 4dc337a717
commit 0ad029bf96

View File

@ -211,8 +211,8 @@ public final class NioEventLoop extends SingleThreadEventLoop {
* {@code 50}, which means the event loop will try to spend the same amount of time for I/O as for non-I/O tasks. * {@code 50}, which means the event loop will try to spend the same amount of time for I/O as for non-I/O tasks.
*/ */
public void setIoRatio(int ioRatio) { public void setIoRatio(int ioRatio) {
if (ioRatio <= 0 || ioRatio >= 100) { if (ioRatio <= 0 || ioRatio > 100) {
throw new IllegalArgumentException("ioRatio: " + ioRatio + " (expected: 0 < ioRatio < 100)"); throw new IllegalArgumentException("ioRatio: " + ioRatio + " (expected: 0 < ioRatio < 101)");
} }
this.ioRatio = ioRatio; this.ioRatio = ioRatio;
} }
@ -339,18 +339,19 @@ public final class NioEventLoop extends SingleThreadEventLoop {
} }
cancelledKeys = 0; cancelledKeys = 0;
final long ioStartTime = System.nanoTime();
needsToSelectAgain = false; needsToSelectAgain = false;
if (selectedKeys != null) {
processSelectedKeysOptimized(selectedKeys.flip());
} else {
processSelectedKeysPlain(selector.selectedKeys());
}
final long ioTime = System.nanoTime() - ioStartTime;
final int ioRatio = this.ioRatio; final int ioRatio = this.ioRatio;
if (ioRatio == 100) {
processSelectedKeys();
runAllTasks();
} else {
final long ioStartTime = System.nanoTime();
processSelectedKeys();
final long ioTime = System.nanoTime() - ioStartTime;
runAllTasks(ioTime * (100 - ioRatio) / ioRatio); runAllTasks(ioTime * (100 - ioRatio) / ioRatio);
}
if (isShuttingDown()) { if (isShuttingDown()) {
closeAll(); closeAll();
@ -372,6 +373,14 @@ public final class NioEventLoop extends SingleThreadEventLoop {
} }
} }
private void processSelectedKeys() {
if (selectedKeys != null) {
processSelectedKeysOptimized(selectedKeys.flip());
} else {
processSelectedKeysPlain(selector.selectedKeys());
}
}
@Override @Override
protected void cleanup() { protected void cleanup() {
try { try {