Class QueueChannel
java.lang.Object
org.springframework.integration.context.IntegrationObjectSupport
org.springframework.integration.channel.AbstractMessageChannel
org.springframework.integration.channel.AbstractPollableChannel
org.springframework.integration.channel.QueueChannel
- All Implemented Interfaces:
- Aware,- BeanFactoryAware,- BeanNameAware,- DisposableBean,- InitializingBean,- ApplicationContextAware,- ExecutorChannelInterceptorAware,- QueueChannelOperations,- ExpressionCapable,- IntegrationPattern,- NamedComponent,- IntegrationManagement,- TrackableComponent,- MessageChannel,- PollableChannel,- InterceptableChannel
- Direct Known Subclasses:
- PriorityChannel,- RendezvousChannel
public class QueueChannel extends AbstractPollableChannel implements QueueChannelOperations
Simple implementation of a message channel. Each 
Message is placed in
 a BlockingQueue whose capacity may be specified upon construction.
 The capacity must be a positive integer value. For a zero-capacity version
 based upon a SynchronousQueue, consider the
 RendezvousChannel.- Author:
- Mark Fisher, Oleg Zhurakousky, Gary Russell, Artem Bilan
- 
Nested Class SummaryNested classes/interfaces inherited from class org.springframework.integration.channel.AbstractMessageChannelAbstractMessageChannel.ChannelInterceptorListNested classes/interfaces inherited from interface org.springframework.integration.support.management.IntegrationManagementIntegrationManagement.ManagementOverrides
- 
Field SummaryFields Modifier and Type Field Description protected SemaphorequeueSemaphoreFields inherited from class org.springframework.integration.channel.AbstractMessageChannelinterceptors, metersFields inherited from class org.springframework.integration.context.IntegrationObjectSupportEXPRESSION_PARSER, loggerFields inherited from interface org.springframework.integration.support.management.IntegrationManagementMETER_PREFIX, RECEIVE_COUNTER_NAME, SEND_TIMER_NAME
- 
Constructor SummaryConstructors Constructor Description QueueChannel()Create a channel with "unbounded" queue capacity.QueueChannel(int capacity)Create a channel with the specified queue capacity.QueueChannel(Queue<Message<?>> queue)Create a channel with the specified queue.
- 
Method SummaryModifier and Type Method Description List<Message<?>>clear()Remove allMessagesfrom this channel.voiddestroy()protected Message<?>doReceive(long timeout)Subclasses must implement this method.protected booleandoSend(Message<?> message, long timeout)Subclasses must implement this method.intgetQueueSize()Obtain the current number of queuedMessagesin this channel.intgetRemainingCapacity()Obtain the remaining capacity of this channel.List<Message<?>>purge(MessageSelector selector)Remove anyMessagesthat are not accepted by the provided selector.voidregisterMetricsCaptor(MetricsCaptor metricsCaptor)Inject aMetricsCaptor.Methods inherited from class org.springframework.integration.channel.AbstractPollableChanneladdInterceptor, addInterceptor, getIntegrationPatternType, hasExecutorInterceptors, receive, receive, removeInterceptor, removeInterceptor, setInterceptorsMethods inherited from class org.springframework.integration.channel.AbstractMessageChannelgetComponentType, getFullChannelName, getIChannelInterceptorList, getInterceptors, getMetricsCaptor, getOverrides, isLoggingEnabled, onInit, send, send, setDatatypes, setLoggingEnabled, setMessageConverter, setShouldTrackMethods inherited from class org.springframework.integration.context.IntegrationObjectSupportafterPropertiesSet, extractTypeIfPossible, generateId, getApplicationContext, getApplicationContextId, getBeanDescription, getBeanFactory, getBeanName, getChannelResolver, getComponentName, getConversionService, getExpression, getIntegrationProperties, getIntegrationProperty, getMessageBuilderFactory, getTaskScheduler, isInitialized, setApplicationContext, setBeanFactory, setBeanName, setChannelResolver, setComponentName, setConversionService, setMessageBuilderFactory, setPrimaryExpression, setTaskScheduler, toStringMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.integration.support.management.IntegrationManagementgetManagedName, getManagedType, getThisAs, setManagedName, setManagedTypeMethods inherited from interface org.springframework.messaging.support.InterceptableChannelgetInterceptorsMethods inherited from interface org.springframework.integration.support.context.NamedComponentgetBeanName, getComponentName
- 
Field Details
- 
Constructor Details- 
QueueChannelCreate a channel with the specified queue.- Parameters:
- queue- The queue.
 
- 
QueueChannelpublic QueueChannel(int capacity)Create a channel with the specified queue capacity.- Parameters:
- capacity- The capacity.
 
- 
QueueChannelpublic QueueChannel()Create a channel with "unbounded" queue capacity. The actual capacity value isInteger.MAX_VALUE. Note that a bounded queue is recommended, since an unbounded queue may lead to OutOfMemoryErrors.
 
- 
- 
Method Details- 
registerMetricsCaptorDescription copied from interface:IntegrationManagementInject aMetricsCaptor.- Specified by:
- registerMetricsCaptorin interface- IntegrationManagement
- Overrides:
- registerMetricsCaptorin class- AbstractMessageChannel
- Parameters:
- metricsCaptor- the captor.
 
- 
doSendDescription copied from class:AbstractMessageChannelSubclasses must implement this method. A non-negative timeout indicates how long to wait if the channel is at capacity (if the value is 0, it must return immediately with or without success). A negative timeout value indicates that the method should block until either the message is accepted or the blocking thread is interrupted.- Specified by:
- doSendin class- AbstractMessageChannel
- Parameters:
- message- The message.
- timeout- The timeout.
- Returns:
- true if the send was successful.
 
- 
doReceiveDescription copied from class:AbstractPollableChannelSubclasses must implement this method. A non-negative timeout indicates how long to wait if the channel is empty (if the value is 0, it must return immediately with or without success). A negative timeout value indicates that the method should block until either a message is available or the blocking thread is interrupted.- Specified by:
- doReceivein class- AbstractPollableChannel
- Parameters:
- timeout- The timeout.
- Returns:
- The message, or null.
 
- 
clearDescription copied from interface:QueueChannelOperationsRemove allMessagesfrom this channel.- Specified by:
- clearin interface- QueueChannelOperations
- Returns:
- The messages that were removed.
 
- 
purgeDescription copied from interface:QueueChannelOperationsRemove anyMessagesthat are not accepted by the provided selector.- Specified by:
- purgein interface- QueueChannelOperations
- Parameters:
- selector- The message selector.
- Returns:
- The list of messages that were purged.
 
- 
getQueueSizepublic int getQueueSize()Description copied from interface:QueueChannelOperationsObtain the current number of queuedMessagesin this channel.- Specified by:
- getQueueSizein interface- QueueChannelOperations
- Returns:
- The current number of queued Messagesin this channel.
 
- 
getRemainingCapacitypublic int getRemainingCapacity()Description copied from interface:QueueChannelOperationsObtain the remaining capacity of this channel.- Specified by:
- getRemainingCapacityin interface- QueueChannelOperations
- Returns:
- The remaining capacity of this channel.
 
- 
destroypublic void destroy()- Specified by:
- destroyin interface- DisposableBean
- Specified by:
- destroyin interface- IntegrationManagement
- Overrides:
- destroyin class- AbstractMessageChannel
 
 
-