mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2024-12-26 06:07:59 +01:00
Re-use executorService as listenerExecutor
This commit is contained in:
parent
f4f7eca7ca
commit
1302dbe9cb
1 changed files with 25 additions and 18 deletions
|
@ -28,8 +28,6 @@ import java.util.concurrent.ConcurrentHashMap;
|
|||
import java.util.concurrent.ConcurrentLinkedQueue;
|
||||
import java.util.concurrent.CopyOnWriteArrayList;
|
||||
import java.util.concurrent.CopyOnWriteArraySet;
|
||||
import java.util.concurrent.ExecutorService;
|
||||
import java.util.concurrent.Executors;
|
||||
import java.util.concurrent.ScheduledExecutorService;
|
||||
import java.util.concurrent.ScheduledFuture;
|
||||
import java.util.concurrent.ScheduledThreadPoolExecutor;
|
||||
|
@ -202,7 +200,29 @@ public abstract class XMPPConnection {
|
|||
|
||||
protected XMPPInputOutputStream compressionHandler;
|
||||
|
||||
private final ScheduledExecutorService executorService = new ScheduledThreadPoolExecutor(2);
|
||||
private final ScheduledExecutorService executorService = new ScheduledThreadPoolExecutor(2,
|
||||
new SmackExecutorThreadFactory(connectionCounterValue));
|
||||
|
||||
/**
|
||||
* SmackExecutorThreadFactory is a *static* inner class of XMPPConnection. Note that we must not
|
||||
* use anonymous classes in order to prevent threads from leaking.
|
||||
*/
|
||||
private static final class SmackExecutorThreadFactory implements ThreadFactory {
|
||||
private final int connectionCounterValue;
|
||||
private int count = 0;
|
||||
|
||||
private SmackExecutorThreadFactory(int connectionCounterValue) {
|
||||
this.connectionCounterValue = connectionCounterValue;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Thread newThread(Runnable runnable) {
|
||||
Thread thread = new Thread(runnable, "Smack Executor Service " + count++ + " ("
|
||||
+ connectionCounterValue + ")");
|
||||
thread.setDaemon(true);
|
||||
return thread;
|
||||
}
|
||||
}
|
||||
|
||||
private Roster roster;
|
||||
|
||||
|
@ -243,19 +263,6 @@ public abstract class XMPPConnection {
|
|||
*/
|
||||
protected boolean wasAuthenticated = false;
|
||||
|
||||
/**
|
||||
* Create an executor to deliver incoming packets to listeners. We'll use a single thread with an unbounded queue.
|
||||
*/
|
||||
private ExecutorService listenerExecutor = Executors.newSingleThreadExecutor(new ThreadFactory() {
|
||||
|
||||
public Thread newThread(Runnable runnable) {
|
||||
Thread thread = new Thread(runnable,
|
||||
"Smack Listener Processor (" + connectionCounterValue + ")");
|
||||
thread.setDaemon(true);
|
||||
return thread;
|
||||
}
|
||||
});
|
||||
|
||||
/**
|
||||
* Create a new XMPPConnection to a XMPP server.
|
||||
*
|
||||
|
@ -1111,7 +1118,7 @@ public abstract class XMPPConnection {
|
|||
}
|
||||
|
||||
// Deliver the incoming packet to listeners.
|
||||
listenerExecutor.submit(new ListenerNotification(packet));
|
||||
executorService.submit(new ListenerNotification(packet));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1327,7 +1334,7 @@ public abstract class XMPPConnection {
|
|||
// reference to their ExecutorService which prevents the ExecutorService from being
|
||||
// gc'ed. It is possible that the XMPPConnection instance is gc'ed while the
|
||||
// listenerExecutor ExecutorService call not be gc'ed until it got shut down.
|
||||
listenerExecutor.shutdownNow();
|
||||
executorService.shutdownNow();
|
||||
}
|
||||
finally {
|
||||
super.finalize();
|
||||
|
|
Loading…
Reference in a new issue