Package io.vertx.servicediscovery.types
Class AbstractServiceReference<T>
- java.lang.Object
- 
- io.vertx.servicediscovery.types.AbstractServiceReference<T>
 
- 
- Type Parameters:
- T- the type of service object
 - All Implemented Interfaces:
- ServiceReference,- AutoCloseable
 
 public abstract class AbstractServiceReference<T> extends Object implements ServiceReference A class to simplify the implementation of service reference. It stores the service object once retrieved. This class handles the synchronization, so callbacks are called with the monitor lock to avoid concurrent accesses.- Author:
- Clement Escoffier
 
- 
- 
Constructor SummaryConstructors Constructor Description AbstractServiceReference(Vertx vertx, ServiceDiscovery discovery, Record record)Creates a new instance ofAbstractServiceReference.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description <X> Xcached()Returns the service object.<X> XcachedAs(Class<X> x)GGets the service object if already retrieved.voidclose()Same asrelease(), here to implementAutoCloseable.<X> Xget()Gets the service object.<X> XgetAs(Class<X> x)Gets the service object.booleanisHolding(Object object)Checks whether or not the service reference has the given service object.protected voidonClose()Callback that let you cleanup the service object.Recordrecord()voidrelease()If the service object has been retrieved, callsonClose()and release the reference.protected abstract Tretrieve()Method to implement to retrieve the service object.
 
- 
- 
- 
Constructor Detail- 
AbstractServiceReferencepublic AbstractServiceReference(Vertx vertx, ServiceDiscovery discovery, Record record) Creates a new instance ofAbstractServiceReference.- Parameters:
- vertx- the vert.x instance
- record- the service record
 
 
- 
 - 
Method Detail- 
cachedpublic <X> X cached() Returns the service object. If not retrieved or released, it returnsnull.- Specified by:
- cachedin interface- ServiceReference
- Returns:
- the cached service object, nullif none
 
 - 
getpublic <X> X get() Gets the service object. If not retrieved, callretrieve(), otherwise returned the cached value.- Specified by:
- getin interface- ServiceReference
- Returns:
- the service object
 
 - 
getAspublic <X> X getAs(Class<X> x) Gets the service object. It can be a proxy, a client or whatever object depending on the service type. Unlikeget()this method let you configure the type of object you want to retrieve. This parameter must match the expected service type, and must pass the "polyglot" version of the class.- Specified by:
- getAsin interface- ServiceReference
- Type Parameters:
- X- the type of object
- Parameters:
- x- the
- Returns:
- the object to access the service
 
 - 
cachedAspublic <X> X cachedAs(Class<X> x) GGets the service object if already retrieved. It won't try to acquire the service object if not retrieved yet. Unlikecached()this method let you configure the type of object you want to retrieve. This parameter must match the expected service type, and must pass the "polyglot" version of the class.- Specified by:
- cachedAsin interface- ServiceReference
- Type Parameters:
- X- the type of object
- Parameters:
- x- the
- Returns:
- the object to access the service
 
 - 
retrieveprotected abstract T retrieve() Method to implement to retrieve the service object. It can be a proxy creation, or a new client. This method is called once, then the return is cached.- Returns:
- the service object
 
 - 
onCloseprotected void onClose() Callback that let you cleanup the service object. This callback is only called if the service objects has been retrieved.
 - 
recordpublic Record record() - Specified by:
- recordin interface- ServiceReference
- Returns:
- the service record.
 
 - 
releasepublic void release() If the service object has been retrieved, callsonClose()and release the reference. Otherwise, does nothing.- Specified by:
- releasein interface- ServiceReference
 
 - 
closepublic void close() Same asrelease(), here to implementAutoCloseable.- Specified by:
- closein interface- AutoCloseable
 
 - 
isHoldingpublic boolean isHolding(Object object) Description copied from interface:ServiceReferenceChecks whether or not the service reference has the given service object.- Specified by:
- isHoldingin interface- ServiceReference
- Parameters:
- object- the service object, must not be- null
- Returns:
- trueif the service reference service object is equal to the given object,- falseotherwise.
 
 
- 
 
-