Javadoc
This commit is contained in:
parent
29da430183
commit
d16639d3ea
@ -153,6 +153,8 @@ public interface ChannelHandlerContext {
|
|||||||
/**
|
/**
|
||||||
* Retrieves an object which is {@link #setAttachment(Object) attached} to
|
* Retrieves an object which is {@link #setAttachment(Object) attached} to
|
||||||
* this context.
|
* this context.
|
||||||
|
* <p>
|
||||||
|
* As an alternative, you might want to use a {@link ChannelLocal} variable.
|
||||||
*
|
*
|
||||||
* @return {@code null} if no object was attached or
|
* @return {@code null} if no object was attached or
|
||||||
* {@code null} was attached
|
* {@code null} was attached
|
||||||
@ -163,6 +165,8 @@ public interface ChannelHandlerContext {
|
|||||||
* Attaches an object to this context to store a stateful information
|
* Attaches an object to this context to store a stateful information
|
||||||
* specific to the {@link ChannelHandler} which is associated with this
|
* specific to the {@link ChannelHandler} which is associated with this
|
||||||
* context.
|
* context.
|
||||||
|
* <p>
|
||||||
|
* As an alternative, you might want to use a {@link ChannelLocal} variable.
|
||||||
*/
|
*/
|
||||||
void setAttachment(Object attachment);
|
void setAttachment(Object attachment);
|
||||||
}
|
}
|
@ -27,6 +27,14 @@ import java.util.concurrent.ConcurrentMap;
|
|||||||
import org.jboss.netty.util.internal.ConcurrentIdentityWeakKeyHashMap;
|
import org.jboss.netty.util.internal.ConcurrentIdentityWeakKeyHashMap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* A global variable that is local to a {@link Channel}. Think of this as a
|
||||||
|
* variation of {@link ThreadLocal} whose key is a {@link Channel} rather than
|
||||||
|
* a {@link Thread#currentThread()}. One difference is that you always have to
|
||||||
|
* specify the {@link Channel} to access the variable.
|
||||||
|
* <p>
|
||||||
|
* As an alternative, you might want to use an attachment storage provided by
|
||||||
|
* {@link ChannelHandlerContext}.
|
||||||
|
*
|
||||||
* @author The Netty Project (netty-dev@lists.jboss.org)
|
* @author The Netty Project (netty-dev@lists.jboss.org)
|
||||||
* @author Trustin Lee (tlee@redhat.com)
|
* @author Trustin Lee (tlee@redhat.com)
|
||||||
* @version $Rev$, $Date$
|
* @version $Rev$, $Date$
|
||||||
@ -45,10 +53,17 @@ public class ChannelLocal<T> {
|
|||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the initial value of the variable. By default, it returns
|
||||||
|
* {@code null}. Override it to change the initial value.
|
||||||
|
*/
|
||||||
protected T initialValue(@SuppressWarnings("unused") Channel channel) {
|
protected T initialValue(@SuppressWarnings("unused") Channel channel) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the value of this variable.
|
||||||
|
*/
|
||||||
public T get(Channel channel) {
|
public T get(Channel channel) {
|
||||||
if (channel == null) {
|
if (channel == null) {
|
||||||
throw new NullPointerException("channel");
|
throw new NullPointerException("channel");
|
||||||
@ -67,6 +82,11 @@ public class ChannelLocal<T> {
|
|||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the value of this variable.
|
||||||
|
*
|
||||||
|
* @return the old value. {@code null} if there was no old value.
|
||||||
|
*/
|
||||||
public T set(Channel channel, T value) {
|
public T set(Channel channel, T value) {
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
return remove(channel);
|
return remove(channel);
|
||||||
@ -78,6 +98,12 @@ public class ChannelLocal<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the value of this variable only when no value was set.
|
||||||
|
*
|
||||||
|
* @return {@code null} if the specified value was set.
|
||||||
|
* An existing value if failed to set.
|
||||||
|
*/
|
||||||
public T setIfAbsent(Channel channel, T value) {
|
public T setIfAbsent(Channel channel, T value) {
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
return get(channel);
|
return get(channel);
|
||||||
@ -89,6 +115,11 @@ public class ChannelLocal<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the variable.
|
||||||
|
*
|
||||||
|
* @return the removed value. {@code null} if no value was set.
|
||||||
|
*/
|
||||||
public T remove(Channel channel) {
|
public T remove(Channel channel) {
|
||||||
if (channel == null) {
|
if (channel == null) {
|
||||||
throw new NullPointerException("channel");
|
throw new NullPointerException("channel");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user