org.wildfly.common.ref.SoftReference Maven / Gradle / Ivy
/*
* JBoss, Home of Professional Open Source.
* Copyright 2014 Red Hat, Inc., and individual contributors
* as indicated by the @author tags.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.wildfly.common.ref;
import java.lang.ref.ReferenceQueue;
/**
* A reapable soft reference with an attachment. If a {@link Reaper} is given, then it will be used to asynchronously
* clean up the referent.
*
* @param the reference value type
* @param the attachment type
*
* @see java.lang.ref.SoftReference
*
* @author David M. Lloyd
*/
public class SoftReference extends java.lang.ref.SoftReference implements Reference, Reapable {
private final A attachment;
private final Reaper reaper;
/**
* Construct a new instance.
*
* @param referent the referent
*/
public SoftReference(final T referent) {
this(referent, null, (ReferenceQueue) null);
}
/**
* Construct a new instance.
*
* @param referent the referent
* @param attachment the attachment
*/
public SoftReference(final T referent, final A attachment) {
this(referent, attachment, (ReferenceQueue) null);
}
/**
* Construct a new instance with an explicit reference queue.
*
* @param referent the referent
* @param attachment the attachment
* @param q the reference queue to use
*/
public SoftReference(final T referent, final A attachment, final ReferenceQueue super T> q) {
super(referent, q);
reaper = null;
this.attachment = attachment;
}
/**
* Construct a new instance with a reaper.
*
* @param referent the referent
* @param attachment the attachment
* @param reaper the reaper to use
*/
public SoftReference(final T referent, final A attachment, final Reaper reaper) {
super(referent, References.ReaperThread.REAPER_QUEUE);
this.reaper = reaper;
this.attachment = attachment;
}
public Reaper getReaper() {
return reaper;
}
public A getAttachment() {
return attachment;
}
public Type getType() {
return Type.SOFT;
}
public String toString() {
return "soft reference to " + String.valueOf(get());
}
}