-
- All Superinterfaces:
- AutoCloseable, MessageProducer
public interface QueueSender extends MessageProducer
A client uses aQueueSender
object to send messages to a queue.Normally, the
Queue
is specified when aQueueSender
is created. In this case, an attempt to use thesend
methods for an unidentifiedQueueSender
will throw ajava.lang.UnsupportedOperationException
.If the
QueueSender
is created with an unidentifiedQueue
, an attempt to use thesend
methods that assume that theQueue
has been identified will throw ajava.lang.UnsupportedOperationException
.During the execution of its
send
method, a message must not be changed by other threads within the client. If the message is modified, the result of thesend
is undefined.After sending a message, a client may retain and modify it without affecting the message that has been sent. The same message object may be sent multiple times.
The following message headers are set as part of sending a message:
JMSDestination
,JMSDeliveryMode
,JMSExpiration
,JMSPriority
,JMSMessageID
andJMSTimeStamp
. When the message is sent, the values of these headers are ignored. After the completion of thesend
, the headers hold the values specified by the method sending the message. It is possible for thesend
method not to setJMSMessageID
andJMSTimeStamp
if the setting of these headers is explicitly disabled by theMessageProducer.setDisableMessageID
orMessageProducer.setDisableMessageTimestamp
method.Creating a
MessageProducer
provides the same features as creating aQueueSender
. AMessageProducer
object is recommended when creating new code. TheQueueSender
is provided to support existing code.- Since:
- JMS 1.0
- Version:
- JMS 2.0
- See Also:
MessageProducer
,Session.createProducer(Destination)
,QueueSession.createSender(Queue)
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method and Description Queue
getQueue()
Gets the queue associated with thisQueueSender
.void
send(Message message)
Sends a message to the queue.void
send(Message message, int deliveryMode, int priority, long timeToLive)
Sends a message to the queue, specifying delivery mode, priority, and time to live.void
send(Queue queue, Message message)
Sends a message to a queue for an unidentified message producer.void
send(Queue queue, Message message, int deliveryMode, int priority, long timeToLive)
Sends a message to a queue for an unidentified message producer, specifying delivery mode, priority and time to live.-
Methods inherited from interface javax.jms.MessageProducer
close, getDeliveryDelay, getDeliveryMode, getDestination, getDisableMessageID, getDisableMessageTimestamp, getPriority, getTimeToLive, send, send, send, send, send, send, setDeliveryDelay, setDeliveryMode, setDisableMessageID, setDisableMessageTimestamp, setPriority, setTimeToLive
-
-
-
-
Method Detail
-
getQueue
Queue getQueue() throws JMSException
Gets the queue associated with thisQueueSender
.- Returns:
- this sender's queue
- Throws:
JMSException
- if the JMS provider fails to get the queue for thisQueueSender
due to some internal error.
-
send
void send(Message message) throws JMSException
Sends a message to the queue. Uses theQueueSender
's default delivery mode, priority, and time to live.- Specified by:
send
in interfaceMessageProducer
- Parameters:
message
- the message to send- Throws:
JMSException
- if the JMS provider fails to send the message due to some internal error.MessageFormatException
- if an invalid message is specified.InvalidDestinationException
- if a client uses this method with aQueueSender
with an invalid queue.UnsupportedOperationException
- if a client uses this method with aQueueSender
that did not specify a queue at creation time.- See Also:
MessageProducer.getDeliveryMode()
,MessageProducer.getTimeToLive()
,MessageProducer.getPriority()
-
send
void send(Message message, int deliveryMode, int priority, long timeToLive) throws JMSException
Sends a message to the queue, specifying delivery mode, priority, and time to live.- Specified by:
send
in interfaceMessageProducer
- Parameters:
message
- the message to senddeliveryMode
- the delivery mode to usepriority
- the priority for this messagetimeToLive
- the message's lifetime (in milliseconds)- Throws:
JMSException
- if the JMS provider fails to send the message due to some internal error.MessageFormatException
- if an invalid message is specified.InvalidDestinationException
- if a client uses this method with aQueueSender
with an invalid queue.UnsupportedOperationException
- if a client uses this method with aQueueSender
that did not specify a queue at creation time.- See Also:
Session.createProducer(javax.jms.Destination)
-
send
void send(Queue queue, Message message) throws JMSException
Sends a message to a queue for an unidentified message producer. Uses theQueueSender
's default delivery mode, priority, and time to live.Typically, a message producer is assigned a queue at creation time; however, the JMS API also supports unidentified message producers, which require that the queue be supplied every time a message is sent.
- Parameters:
queue
- the queue to send this message tomessage
- the message to send- Throws:
JMSException
- if the JMS provider fails to send the message due to some internal error.MessageFormatException
- if an invalid message is specified.InvalidDestinationException
- if a client uses this method with an invalid queue.- See Also:
MessageProducer.getDeliveryMode()
,MessageProducer.getTimeToLive()
,MessageProducer.getPriority()
-
send
void send(Queue queue, Message message, int deliveryMode, int priority, long timeToLive) throws JMSException
Sends a message to a queue for an unidentified message producer, specifying delivery mode, priority and time to live.Typically, a message producer is assigned a queue at creation time; however, the JMS API also supports unidentified message producers, which require that the queue be supplied every time a message is sent.
- Parameters:
queue
- the queue to send this message tomessage
- the message to senddeliveryMode
- the delivery mode to usepriority
- the priority for this messagetimeToLive
- the message's lifetime (in milliseconds)- Throws:
JMSException
- if the JMS provider fails to send the message due to some internal error.MessageFormatException
- if an invalid message is specified.InvalidDestinationException
- if a client uses this method with an invalid queue.
-
-
Traduction non disponible
Les API Java ne sont pas encore traduites en français sur l'infobrol. Seule la version anglaise est disponible pour l'instant.
Version en cache
07/10/2025 04:12:19 Cette version de la page est en cache (à la date du 07/10/2025 04:12:19) afin d'accélérer le traitement.Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la version plus récente de la page.
Document créé le 14/04/2008, dernière modification le 18/08/2025
Source du document imprimé : https://www.gaudry.be/java-api-javaee-rf-javax/jms/QueueSender.html
L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.
Références
Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.