Added the comment as suggested by Thomas Bocek
This commit is contained in:
parent
2fa19ff845
commit
404abfd198
@ -645,6 +645,13 @@ class NioDatagramWorker implements Runnable {
|
|||||||
boolean connected = channel.isConnected();
|
boolean connected = channel.isConnected();
|
||||||
boolean bound = channel.isBound();
|
boolean bound = channel.isBound();
|
||||||
try {
|
try {
|
||||||
|
// It is necessary to cancel all keys before closing a socket
|
||||||
|
// because the shutdown flag in the Selector loop is set only when
|
||||||
|
// all keys are cancelled. Thus, SocketChannel.close() and
|
||||||
|
// SelectionKey.cancel() must be placed in a synchronized block.
|
||||||
|
// Otherwise SocketChannel.register() in RegisterTask can be called
|
||||||
|
// after cancel(), but before close(), resulting in the infinite
|
||||||
|
// Selector loop that refuses to shut down due to the dangling keys.
|
||||||
synchronized (channel.interestOpsLock) {
|
synchronized (channel.interestOpsLock) {
|
||||||
SelectionKey key = channel.getDatagramChannel().keyFor(selector);
|
SelectionKey key = channel.getDatagramChannel().keyFor(selector);
|
||||||
if (key != null) {
|
if (key != null) {
|
||||||
|
@ -559,6 +559,13 @@ class NioWorker implements Runnable {
|
|||||||
boolean connected = channel.isConnected();
|
boolean connected = channel.isConnected();
|
||||||
boolean bound = channel.isBound();
|
boolean bound = channel.isBound();
|
||||||
try {
|
try {
|
||||||
|
// It is necessary to cancel all keys before closing a socket
|
||||||
|
// because the shutdown flag in the Selector loop is set only when
|
||||||
|
// all keys are cancelled. Thus, SocketChannel.close() and
|
||||||
|
// SelectionKey.cancel() must be placed in a synchronized block.
|
||||||
|
// Otherwise SocketChannel.register() in RegisterTask can be called
|
||||||
|
// after cancel(), but before close(), resulting in the infinite
|
||||||
|
// Selector loop that refuses to shut down due to the dangling keys.
|
||||||
synchronized (channel.interestOpsLock) {
|
synchronized (channel.interestOpsLock) {
|
||||||
SelectionKey key = channel.socket.keyFor(selector);
|
SelectionKey key = channel.socket.keyFor(selector);
|
||||||
if (key != null) {
|
if (key != null) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user