From c09d716d345ac0c9d31f63845220669ec32102b0 Mon Sep 17 00:00:00 2001 From: Xueming Shen Date: Wed, 16 Jul 2008 15:24:15 -0700 Subject: [PATCH] 6429289: (se) sun.nio.ch.SelectorImpl.processDeregisterQueue creates excessive garbage Check if the cancelledKeys is empty or not before creating iterator Reviewed-by: alanb --- .../classes/sun/nio/ch/SelectorImpl.java | 26 ++++++++++--------- 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/jdk/src/share/classes/sun/nio/ch/SelectorImpl.java b/jdk/src/share/classes/sun/nio/ch/SelectorImpl.java index 828a37c712d..f092db00d79 100644 --- a/jdk/src/share/classes/sun/nio/ch/SelectorImpl.java +++ b/jdk/src/share/classes/sun/nio/ch/SelectorImpl.java @@ -142,18 +142,20 @@ abstract class SelectorImpl // Precondition: Synchronized on this, keys, and selectedKeys Set cks = cancelledKeys(); synchronized (cks) { - Iterator i = cks.iterator(); - while (i.hasNext()) { - SelectionKeyImpl ski = (SelectionKeyImpl)i.next(); - try { - implDereg(ski); - } catch (SocketException se) { - IOException ioe = new IOException( - "Error deregistering key"); - ioe.initCause(se); - throw ioe; - } finally { - i.remove(); + if (!cks.isEmpty()) { + Iterator i = cks.iterator(); + while (i.hasNext()) { + SelectionKeyImpl ski = (SelectionKeyImpl)i.next(); + try { + implDereg(ski); + } catch (SocketException se) { + IOException ioe = new IOException( + "Error deregistering key"); + ioe.initCause(se); + throw ioe; + } finally { + i.remove(); + } } } }