Class ReferenceCountUtil
java.lang.Object
io.netty.util.ReferenceCountUtil
Collection of method to handle objects that may implement
ReferenceCounted.-
Method Summary
Modifier and TypeMethodDescriptionstatic intReturns reference count of aReferenceCountedobject.static booleanTry to callReferenceCounted.release()if the specified message implementsReferenceCounted.static booleanTry to callReferenceCounted.release(int)if the specified message implementsReferenceCounted.static <T> TreleaseLater(T msg) Deprecated.this may introduce a lot of memory usage so it is generally preferable to manually release objects.static <T> TreleaseLater(T msg, int decrement) Deprecated.this may introduce a lot of memory usage so it is generally preferable to manually release objects.static <T> Tretain(T msg) Try to callReferenceCounted.retain()if the specified message implementsReferenceCounted.static <T> Tretain(T msg, int increment) Try to callReferenceCounted.retain(int)if the specified message implementsReferenceCounted.static voidsafeRelease(Object msg) Try to callReferenceCounted.release()if the specified message implementsReferenceCounted.static voidsafeRelease(Object msg, int decrement) Try to callReferenceCounted.release(int)if the specified message implementsReferenceCounted.static <T> Ttouch(T msg) Tries to callReferenceCounted.touch()if the specified message implementsReferenceCounted.static <T> TTries to callReferenceCounted.touch(Object)if the specified message implementsReferenceCounted.
-
Method Details
-
retain
public static <T> T retain(T msg) Try to callReferenceCounted.retain()if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. -
retain
public static <T> T retain(T msg, int increment) Try to callReferenceCounted.retain(int)if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. -
touch
public static <T> T touch(T msg) Tries to callReferenceCounted.touch()if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. -
touch
Tries to callReferenceCounted.touch(Object)if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. -
release
Try to callReferenceCounted.release()if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. -
release
Try to callReferenceCounted.release(int)if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. -
safeRelease
Try to callReferenceCounted.release()if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. Unlikerelease(Object)this method catches an exception raised byReferenceCounted.release()and logs it, rather than rethrowing it to the caller. It is usually recommended to userelease(Object)instead, unless you absolutely need to swallow an exception. -
safeRelease
Try to callReferenceCounted.release(int)if the specified message implementsReferenceCounted. If the specified message doesn't implementReferenceCounted, this method does nothing. Unlikerelease(Object)this method catches an exception raised byReferenceCounted.release(int)and logs it, rather than rethrowing it to the caller. It is usually recommended to userelease(Object, int)instead, unless you absolutely need to swallow an exception. -
releaseLater
Deprecated.this may introduce a lot of memory usage so it is generally preferable to manually release objects.Schedules the specified object to be released when the caller thread terminates. Note that this operation is intended to simplify reference counting of ephemeral objects during unit tests. Do not use it beyond the intended use case. -
releaseLater
Deprecated.this may introduce a lot of memory usage so it is generally preferable to manually release objects.Schedules the specified object to be released when the caller thread terminates. Note that this operation is intended to simplify reference counting of ephemeral objects during unit tests. Do not use it beyond the intended use case. -
refCnt
Returns reference count of aReferenceCountedobject. If object is not type ofReferenceCounted,-1is returned.
-