All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.aspectj.weaver.bcel.BcelWeakClassLoaderReference Maven / Gradle / Ivy

Go to download

AspectJ tools most notably contains the AspectJ compiler (AJC). AJC applies aspects to Java classes during compilation, fully replacing Javac for plain Java classes and also compiling native AspectJ or annotation-based @AspectJ syntax. Furthermore, AJC can weave aspects into existing class files in a post-compile binary weaving step. This library is a superset of AspectJ weaver and hence also of AspectJ runtime.

There is a newer version: 1.9.22.1
Show newest version
/* *******************************************************************
 * Copyright (c) 2008 Contributors
 * All rights reserved.
 * This program and the accompanying materials are made available
 * under the terms of the Eclipse Public License v 2.0
 * which accompanies this distribution and is available at
 * https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.txt
 *
 * Contributors:
 *     Andy Clement     initial implementation
 * ******************************************************************/
package org.aspectj.weaver.bcel;

import org.aspectj.apache.bcel.util.ClassLoaderReference;
import org.aspectj.weaver.WeakClassLoaderReference;

/**
 * Wraps a reference to a classloader inside a WeakReference. This should be used where we do not want the existence of a
 * classloader reference to prevent garbage collection of that classloader (and possibly an associated weaver instance in the case
 * of load time weaving).
 * 

* In more detail:
* When load time weaving, the class Aj maintains a WeakHashMap from the classloader instance to a weaver instance. The aim is that * the weaver is around as long as the classloader is and should the classloader be dereferenced then the weaver can also be garbage * collected. The problem is that if there are many references to the classloader from within the weaver, these are considered hard * references and cause the classloader to be long lived - even if the user of the classloader has dereferenced it in their code. * The solution is that the weaver should use instances of WeakClassLoaderReference objects - so that when the users hard reference * to the classloader goes, nothing in the weaver will cause it to hang around. There is a big assertion here that the * WeakClassLoaderReference instances will not 'lose' their ClassLoader references until the top level ClassLoader reference is * null'd. This means there is no need to check for the null case on get() in this WeakReference logic below, because we shouldn't * be using this weaver if its associated ClassLoader has been collected. See https://bugs.eclipse.org/bugs/show_bug.cgi?id=210470 * * * @author Andy Clement */ public class BcelWeakClassLoaderReference extends WeakClassLoaderReference implements ClassLoaderReference { public BcelWeakClassLoaderReference(ClassLoader loader) { super(loader); } public boolean equals(Object obj) { if (!(obj instanceof BcelWeakClassLoaderReference)) return false; BcelWeakClassLoaderReference other = (BcelWeakClassLoaderReference) obj; return (other.hashcode == hashcode); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy