1 /** 2 * 3 * Copyright 2005 The Apache Software Foundation 4 * 5 * Licensed under the Apache License, Version 2.0 (the "License"); 6 * you may not use this file except in compliance with the License. 7 * You may obtain a copy of the License at 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 * See the License for the specific language governing permissions and 15 * limitations under the License. 16 */ 17 18 package org.apache.geronimo.kernel.config; 19 20 import java.net.URI; 21 import java.net.URL; 22 import java.net.URLClassLoader; 23 import java.io.ObjectInputStream; 24 import java.io.ObjectOutputStream; 25 import java.io.ObjectStreamClass; 26 import java.util.Map; 27 import java.lang.reflect.Field; 28 29 import org.apache.commons.logging.LogFactory; 30 31 /** 32 * 33 * @version $Rev: 428082 $ $Date: 2006-08-02 11:35:10 -0700 (Wed, 02 Aug 2006) $ 34 */ 35 public class ConfigurationClassLoader extends URLClassLoader { 36 private final URI id; 37 38 public ConfigurationClassLoader(URI id, URL[] urls, ClassLoader parent) { 39 super(urls, parent); 40 this.id = id; 41 } 42 43 public URI getID() { 44 return id; 45 } 46 47 public void destroy() { 48 LogFactory.release(this); 49 clearSoftCache(ObjectInputStream.class, "subclassAudits"); 50 clearSoftCache(ObjectOutputStream.class, "subclassAudits"); 51 clearSoftCache(ObjectStreamClass.class, "localDescs"); 52 clearSoftCache(ObjectStreamClass.class, "reflectors"); 53 } 54 55 public String toString() { 56 return "[Configuration ClassLoader id=" + id + "]"; 57 } 58 59 private static Object lock = new Object(); 60 private static boolean clearSoftCacheFailed = false; 61 private static void clearSoftCache(Class clazz, String fieldName) { 62 Map cache = null; 63 try { 64 Field f = clazz.getDeclaredField(fieldName); 65 f.setAccessible(true); 66 cache = (Map) f.get(null); 67 } catch (Throwable e) { 68 synchronized (lock) { 69 if (!clearSoftCacheFailed) { 70 clearSoftCacheFailed = true; 71 LogFactory.getLog(ConfigurationClassLoader.class).debug("Unable to clear SoftCache field " + fieldName + " in class " + clazz); 72 } 73 } 74 } 75 76 if (cache != null) { 77 synchronized (cache) { 78 cache.clear(); 79 } 80 } 81 } 82 }