Class BusFactory
- Direct Known Subclasses:
- CXFBusFactory,- SpringBusFactory
CXF includes a large number of components that provide services, such as WSDL parsing, and message processing. To avoid creating these objects over and over, and to allow them to be shared easily, they are associated with a data structure called a bus.
You don't ever have to explicitly create or manipulate bus objects. If you simply use the CXF or JAX-WS APIs to create clients or servers, CXF will create a default bus for you. You can create a bus explicitly if you need to customize components on the bus or maintain several independent buses with independent configurations.
This class maintains the default bus for the entire process and a set of thread-default buses. All CXF components that reference the bus, which is to say all CXF components, will obtain a default bus from this class if you do not set a specific bus.
If you create a bus when there is no default bus in effect, that bus will become the default bus.
This class holds a reference to the global default bus and a reference to each thread default bus. The thread references are weak with respect to the threads, but otherwise ordinary. Thus, so long as the thread remains alive there will be a strong reference to the bus, and it will not get garbage-collected. If you want to recover memory used CXF, you can set the default and per-thread default bus to null, explicitly.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final Stringstatic final Stringprotected static Busprotected static final ThreadLocal<org.apache.cxf.BusFactory.BusHolder>
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic voidRemoves a bus from being a thread default bus for any thread.abstract BusCreates a new bus.static BusSets the default bus for the thread.static BusReturns the default bus, creating it if necessary.static BusgetDefaultBus(boolean createIfNeeded) Returns the default busstatic BusGets the default bus for the thread.static BusgetThreadDefaultBus(boolean createIfNeeded) Gets the default bus for the thread, creating if neededprotected voidinitializeBus(Bus bus) static BusFactoryCreate a new BusFactory The class of the BusFactory is determined by looking for the system propery: org.apache.cxf.bus.factory or by searching the classpath for: META-INF/services/org.apache.cxf.bus.factorystatic BusFactorynewInstance(String className) Create a new BusFactorystatic booleanpossiblySetDefaultBus(Bus bus) Sets the default bus if a default bus is not already set.static voidsetDefaultBus(Bus bus) Sets the default bus.static voidsetThreadDefaultBus(Bus bus) Sets the default bus for the thread.
- 
Field Details- 
BUS_FACTORY_PROPERTY_NAME- See Also:
 
- 
DEFAULT_BUS_FACTORY- See Also:
 
- 
defaultBus
- 
THREAD_BUSSES
- 
THREAD_BUS
 
- 
- 
Constructor Details- 
BusFactorypublic BusFactory()
 
- 
- 
Method Details- 
createBusCreates a new bus. While concreteBusFactorymay offer differently parameterized methods for creating a bus, all factories support this no-arg factory method.- Returns:
- the newly created bus.
 
- 
getDefaultBusReturns the default bus, creating it if necessary.- Returns:
- the default bus.
 
- 
getDefaultBusReturns the default bus- Parameters:
- createIfNeeded- Set to true to create a default bus if one doesn't exist
- Returns:
- the default bus.
 
- 
setDefaultBusSets the default bus.- Parameters:
- bus- the default bus.
 
- 
setThreadDefaultBusSets the default bus for the thread.- Parameters:
- bus- the default bus.
 
- 
getAndSetThreadDefaultBusSets the default bus for the thread.- Parameters:
- bus- the new thread default bus.
- Returns:
- the old thread default bus or null
 
- 
getThreadDefaultBusGets the default bus for the thread.- Returns:
- the default bus.
 
- 
getThreadDefaultBusGets the default bus for the thread, creating if needed- Parameters:
- createIfNeeded- Set to true to create a default bus if one doesn't exist
- Returns:
- the default bus.
 
- 
clearDefaultBusForAnyThreadRemoves a bus from being a thread default bus for any thread.This is typically done when a bus has ended its lifecycle (i.e.: a call to Bus.shutdown(boolean)was invoked) and it wants to remove any reference to itself for any thread.- Parameters:
- bus- the bus to remove
 
- 
possiblySetDefaultBusSets the default bus if a default bus is not already set.- Parameters:
- bus- the default bus.
- Returns:
- true if the bus was not set and is now set
 
- 
newInstanceCreate a new BusFactory The class of the BusFactory is determined by looking for the system propery: org.apache.cxf.bus.factory or by searching the classpath for: META-INF/services/org.apache.cxf.bus.factory- Returns:
- a new BusFactory to be used to create Bus objects
 
- 
newInstanceCreate a new BusFactory- Parameters:
- className- The class of the BusFactory to create. If null, uses the default search algorithm.
- Returns:
- a new BusFactory to be used to create Bus objects
 
- 
initializeBus
 
-