⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 queuerequestor.java

📁 JAVA 消息服务(JMS)定义了Java 中访问消息中间件的接口,里边有实现消息服务的基础源码,可以开发高级应用
💻 JAVA
字号:
/* * @(#)QueueRequestor.java	1.21 02/04/09 * * Copyright 1997-2002 Sun Microsystems, Inc. All Rights Reserved. * *  SUN PROPRIETARY/CONFIDENTIAL. * This software is the proprietary information of Sun Microsystems, Inc.   * Use is subject to license terms. *  */package javax.jms;/** The <CODE>QueueRequestor</CODE> helper class simplifies  * making service requests.  *  * <P>The <CODE>QueueRequestor</CODE> constructor is given a non-transacted   * <CODE>QueueSession</CODE> and a destination <CODE>Queue</CODE>. It creates a  * <CODE>TemporaryQueue</CODE> for the responses and provides a   * <CODE>request</CODE> method that sends the request message and waits   * for its reply.  *  * <P>This is a basic request/reply abstraction that should be sufficient   * for most uses. JMS providers and clients are free to create more   * sophisticated versions.  *  * @version     1.0 - 8 July 1998  * @author      Mark Hapner  * @author      Rich Burridge  *  * @see         javax.jms.TopicRequestor  */public class QueueRequestor {    QueueSession   session;     // The queue session the queue belongs to.    Queue          queue;       // The queue to perform the request/reply on.    TemporaryQueue tempQueue;    QueueSender    sender;    QueueReceiver  receiver;    /** Constructor for the <CODE>QueueRequestor</CODE> class.      *        * <P>This implementation assumes the session parameter to be non-transacted,      * with a delivery mode of either <CODE>AUTO_ACKNOWLEDGE</CODE> or       * <CODE>DUPS_OK_ACKNOWLEDGE</CODE>.      *      * @param session the <CODE>QueueSession</CODE> the queue belongs to      * @param queue the queue to perform the request/reply call on      *        * @exception JMSException if the JMS provider fails to create the      *                         <CODE>QueueRequestor</CODE> due to some internal      *                         error.      * @exception InvalidDestinationException if an invalid queue is specified.      */     public    QueueRequestor(QueueSession session, Queue queue) throws JMSException {        this.session = session;        this.queue   = queue;        tempQueue    = session.createTemporaryQueue();        sender       = session.createSender(queue);        receiver     = session.createReceiver(tempQueue);    }    /** Sends a request and waits for a reply. The temporary queue is used for      * the <CODE>JMSReplyTo</CODE> destination, and only one reply per request       * is expected.      *        * @param message the message to send      *        * @return the reply message      *        * @exception JMSException if the JMS provider fails to complete the      *                         request due to some internal error.      */    public Message    request(Message message) throws JMSException {	message.setJMSReplyTo(tempQueue);	sender.send(message);	return (receiver.receive());    }    /** Closes the <CODE>QueueRequestor</CODE> and its session.      *      * <P>Since a provider may allocate some resources on behalf of a       * <CODE>QueueRequestor</CODE> outside the Java virtual machine, clients       * should close them when they       * are not needed. Relying on garbage collection to eventually reclaim       * these resources may not be timely enough.      *        * <P>Note that this method closes the <CODE>QueueSession</CODE> object       * passed to the <CODE>QueueRequestor</CODE> constructor.      *      * @exception JMSException if the JMS provider fails to close the      *                         <CODE>QueueRequestor</CODE> due to some internal      *                         error.      */    public void    close() throws JMSException {	// publisher and consumer created by constructor are implicitly closed.	session.close();        tempQueue.delete();    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -