public class ServiceRegistry extends Object
A service is a well-known set of interfaces and (usually abstract) classes. A service provider is a specific implementation of a service. The classes in a provider typically implement the interface or subclass the class defined by the service itself.
 Service providers are stored in one or more categories,
 each of which is defined by a class of interface (described by a
 Class object) that all of its members must implement.
 The set of categories may be changed dynamically.
 
 Only a single instance of a given leaf class (that is, the
 actual class returned by getClass(), as opposed to any
 inherited classes or interfaces) may be registered.  That is,
 suppose that the
 com.mycompany.mypkg.GreenServiceProvider class
 implements the com.mycompany.mypkg.MyService
 interface.  If a GreenServiceProvider instance is
 registered, it will be stored in the category defined by the
 MyService class.  If a new instance of
 GreenServiceProvider is registered, it will replace
 the previous instance.  In practice, service provider objects are
 usually singletons so this behavior is appropriate.
 
 To declare a service provider, a services
 subdirectory is placed within the META-INF directory
 that is present in every JAR file.  This directory contains a file
 for each service provider interface that has one or more
 implementation classes present in the JAR file.  For example, if
 the JAR file contained a class named
 com.mycompany.mypkg.MyServiceImpl which implements the
 javax.someapi.SomeService interface, the JAR file
 would contain a file named: 
META-INF/services/javax.someapi.SomeServicecontaining the line:
com.mycompany.mypkg.MyService
The service provider classes should be to be lightweight and quick to load. Implementations of these interfaces should avoid complex dependencies on other classes and on native code. The usual pattern for more complex services is to register a lightweight proxy for the heavyweight service.
An application may customize the contents of a registry as it sees fit, so long as it has the appropriate runtime permission.
For more details on declaring service providers, and the JAR format in general, see the JAR File Specification.
RegisterableService| Modifier and Type | Class and Description | 
|---|---|
| static interface  | ServiceRegistry.FilterA simple filter interface used by
  ServiceRegistry.getServiceProvidersto select
 providers matching an arbitrary criterion. | 
| Constructor and Description | 
|---|
| ServiceRegistry(Iterator<Class<?>> categories)Constructs a  ServiceRegistryinstance with a
 set of categories taken from thecategoriesargument. | 
| Modifier and Type | Method and Description | 
|---|---|
| boolean | contains(Object provider)Returns  trueifprovideris currently
 registered. | 
| void | deregisterAll()Deregisters all currently registered service providers from all
 categories. | 
| void | deregisterAll(Class<?> category)Deregisters all service provider object currently registered
 under the given category. | 
| void | deregisterServiceProvider(Object provider)Removes a service provider object from all categories that
 contain it. | 
| <T> boolean | deregisterServiceProvider(T provider,
                         Class<T> category)Removes a service provider object from the given category. | 
| void | finalize()Finalizes this object prior to garbage collection. | 
| Iterator<Class<?>> | getCategories()Returns an  IteratorofClassobjects
 indicating the current set of categories. | 
| <T> T | getServiceProviderByClass(Class<T> providerClass)Returns the currently registered service provider object that
 is of the given class type. | 
| <T> Iterator<T> | getServiceProviders(Class<T> category,
                   boolean useOrdering)Returns an  Iteratorcontaining all registered
 service providers in the given category. | 
| <T> Iterator<T> | getServiceProviders(Class<T> category,
                   ServiceRegistry.Filter filter,
                   boolean useOrdering)Returns an  Iteratorcontaining service provider
 objects within a given category that satisfy a criterion
 imposed by the suppliedServiceRegistry.Filterobject'sfiltermethod. | 
| static <T> Iterator<T> | lookupProviders(Class<T> providerClass)Locates and incrementally instantiates the available providers
 of a given service using the context class loader. | 
| static <T> Iterator<T> | lookupProviders(Class<T> providerClass,
               ClassLoader loader)Searches for implementations of a particular service class
 using the given class loader. | 
| void | registerServiceProvider(Object provider)Adds a service provider object to the registry. | 
| <T> boolean | registerServiceProvider(T provider,
                       Class<T> category)Adds a service provider object to the registry. | 
| void | registerServiceProviders(Iterator<?> providers)Adds a set of service provider objects, taken from an
  Iteratorto the registry. | 
| <T> boolean | setOrdering(Class<T> category,
           T firstProvider,
           T secondProvider)Sets a pairwise ordering between two service provider objects
 within a given category. | 
| <T> boolean | unsetOrdering(Class<T> category,
             T firstProvider,
             T secondProvider)Sets a pairwise ordering between two service provider objects
 within a given category. | 
public ServiceRegistry(Iterator<Class<?>> categories)
ServiceRegistry instance with a
 set of categories taken from the categories
 argument.categories - an Iterator containing
 Class objects to be used to define categories.IllegalArgumentException - if
 categories is null.public static <T> Iterator<T> lookupProviders(Class<T> providerClass, ClassLoader loader)
 This method transforms the name of the given service class
 into a provider-configuration filename as described in the
 class comment and then uses the getResources
 method of the given class loader to find all available files
 with that name.  These files are then read and parsed to
 produce a list of provider-class names.  The iterator that is
 returned uses the given class loader to look up and then
 instantiate each element of the list.
 
Because it is possible for extensions to be installed into a running Java virtual machine, this method may return different results each time it is invoked.
providerClass - a Classobject indicating the
 class or interface of the service providers being detected.loader - the class loader to be used to load
 provider-configuration files and instantiate provider classes,
 or null if the system class loader (or, failing that
 the bootstrap class loader) is to be used.Iterator that yields provider objects
 for the given service, in some arbitrary order.  The iterator
 will throw an Error if a provider-configuration
 file violates the specified format or if a provider class
 cannot be found and instantiated.IllegalArgumentException - if
 providerClass is null.public static <T> Iterator<T> lookupProviders(Class<T> providerClass)
ClassLoader cl = Thread.currentThread().getContextClassLoader(); return Service.providers(service, cl);
providerClass - a Classobject indicating the
 class or interface of the service providers being detected.Iterator that yields provider objects
 for the given service, in some arbitrary order.  The iterator
 will throw an Error if a provider-configuration
 file violates the specified format or if a provider class
 cannot be found and instantiated.IllegalArgumentException - if
 providerClass is null.public Iterator<Class<?>> getCategories()
Iterator of Class objects
 indicating the current set of categories.  The iterator will be
 empty if no categories exist.Iterator containing
 Classobjects.public <T> boolean registerServiceProvider(T provider,
                                  Class<T> category)
 If provider implements the
 RegisterableService interface, its
 onRegistration method will be called.  Its
 onDeregistration method will be called each time
 it is deregistered from a category, for example if a
 category is removed or the registry is garbage collected.
provider - the service provide object to be registered.category - the category under which to register the
 provider.IllegalArgumentException - if provider is
 null.IllegalArgumentException - if there is no category
 corresponding to category.ClassCastException - if provider does not implement
 the Class defined by category.public void registerServiceProvider(Object provider)
Class it implements.
  If provider implements the
 RegisterableService interface, its
 onRegistration method will be called once for each
 category it is registered under.  Its
 onDeregistration method will be called each time
 it is deregistered from a category or when the registry is
 finalized.
provider - the service provider object to be registered.IllegalArgumentException - if
 provider is null.public void registerServiceProviders(Iterator<?> providers)
Iterator to the registry.  Each provider is
 associated within each category present in the registry whose
 Class it implements.
  For each entry of providers that implements
 the RegisterableService interface, its
 onRegistration method will be called once for each
 category it is registered under.  Its
 onDeregistration method will be called each time
 it is deregistered from a category or when the registry is
 finalized.
providers - an Iterator containing service provider
 objects to be registered.IllegalArgumentException - if providers
 is null or contains a null entry.public <T> boolean deregisterServiceProvider(T provider,
                                    Class<T> category)
false is returned.  Otherwise, true
 is returned.  If an object of the same class as
 provider but not equal (using ==) to
 provider is registered, it will not be
 deregistered.
  If provider implements the
 RegisterableService interface, its
 onDeregistration method will be called.
provider - the service provider object to be deregistered.category - the category from which to deregister the
 provider.true if the provider was previously
 registered in the same category category,
 false otherwise.IllegalArgumentException - if provider is
 null.IllegalArgumentException - if there is no category
 corresponding to category.ClassCastException - if provider does not implement
 the class defined by category.public void deregisterServiceProvider(Object provider)
provider - the service provider object to be deregistered.IllegalArgumentException - if provider is
 null.public boolean contains(Object provider)
true if provider is currently
 registered.provider - the service provider object to be queried.true if the given provider has been
 registered.IllegalArgumentException - if provider is
 null.public <T> Iterator<T> getServiceProviders(Class<T> category, boolean useOrdering)
Iterator containing all registered
 service providers in the given category.  If
 useOrdering is false, the iterator
 will return all of the server provider objects in an arbitrary
 order.  Otherwise, the ordering will respect any pairwise
 orderings that have been set.  If the graph of pairwise
 orderings contains cycles, any providers that belong to a cycle
 will not be returned.category - the category to be retrieved from.useOrdering - true if pairwise orderings
 should be taken account in ordering the returned objects.Iterator containing service provider
 objects from the given category, possibly in order.IllegalArgumentException - if there is no category
 corresponding to category.public <T> Iterator<T> getServiceProviders(Class<T> category, ServiceRegistry.Filter filter, boolean useOrdering)
Iterator containing service provider
 objects within a given category that satisfy a criterion
 imposed by the supplied ServiceRegistry.Filter
 object's filter method.
  The useOrdering argument controls the
 ordering of the results using the same rules as
 getServiceProviders(Class, boolean).
category - the category to be retrieved from.filter - an instance of ServiceRegistry.Filter
 whose filter method will be invoked.useOrdering - true if pairwise orderings
 should be taken account in ordering the returned objects.Iterator containing service provider
 objects from the given category, possibly in order.IllegalArgumentException - if there is no category
 corresponding to category.public <T> T getServiceProviderByClass(Class<T> providerClass)
null
 is returned.providerClass - the Class of the desired
 service provider object.Classtype, or null is none is
 present.IllegalArgumentException - if providerClass is
 null.public <T> boolean setOrdering(Class<T> category, T firstProvider, T secondProvider)
false is returned.  If the providers previously
 were ordered in the reverse direction, that ordering is
 removed.
  The ordering will be used by the
 getServiceProviders methods when their
 useOrdering argument is true.
category - a Class object indicating the
 category under which the preference is to be established.firstProvider - the preferred provider.secondProvider - the provider to which
 firstProvider is preferred.true if a previously unset ordering
 was established.IllegalArgumentException - if either provider is
 null or they are the same object.IllegalArgumentException - if there is no category
 corresponding to category.public <T> boolean unsetOrdering(Class<T> category, T firstProvider, T secondProvider)
false is returned.
  The ordering will be used by the
 getServiceProviders methods when their
 useOrdering argument is true.
category - a Class object indicating the
 category under which the preference is to be disestablished.firstProvider - the formerly preferred provider.secondProvider - the provider to which
 firstProvider was formerly preferred.true if a previously set ordering was
 disestablished.IllegalArgumentException - if either provider is
 null or they are the same object.IllegalArgumentException - if there is no category
 corresponding to category.public void deregisterAll(Class<?> category)
category - the category to be emptied.IllegalArgumentException - if there is no category
 corresponding to category.public void deregisterAll()
public void finalize()
              throws Throwable
deregisterAll method is called to deregister all
 currently registered service providers.  This method should not
 be called from application code. Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2011, Oracle and/or its affiliates.  All rights reserved. 
DRAFT ea-b138