8241130: com.sun.jndi.ldap.EventSupport.removeDeadNotifier: java.lang.NullPointerException

Reviewed-by: dfuchs
This commit is contained in:
Chris Yin 2020-03-20 10:24:46 +08:00
parent 3f698242a8
commit 7ded8b1e30
2 changed files with 13 additions and 3 deletions

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -250,7 +250,12 @@ final class EventSupport {
if (debug) { if (debug) {
System.err.println("EventSupport.removeDeadNotifier: " + info.name); System.err.println("EventSupport.removeDeadNotifier: " + info.name);
} }
notifiers.remove(info); if (notifiers != null) {
// Only do this if cleanup() not been triggered, otherwise here
// will throw NullPointerException since notifiers will be set to
// null in cleanup()
notifiers.remove(info);
}
} }
/** /**
@ -329,6 +334,11 @@ final class EventSupport {
*/ */
synchronized void queueEvent(EventObject event, synchronized void queueEvent(EventObject event,
Vector<? extends NamingListener> vector) { Vector<? extends NamingListener> vector) {
if (notifiers == null) {
// That means cleanup() already done, not queue event anymore,
// otherwise, new created EventQueue will not been cleanup.
return;
}
if (eventQueue == null) if (eventQueue == null)
eventQueue = new EventQueue(); eventQueue = new EventQueue();

View File

@ -39,7 +39,7 @@ import jdk.test.lib.net.URIBuilder;
/** /**
* @test * @test
* @bug 8176192 * @bug 8176192 8241130
* @summary Incorrect usage of Iterator in Java 8 In com.sun.jndi.ldap. * @summary Incorrect usage of Iterator in Java 8 In com.sun.jndi.ldap.
* EventSupport.removeNamingListener * EventSupport.removeNamingListener
* @modules java.naming * @modules java.naming