Package aleph

Source Code of aleph.RemoteFunction

/*
* Aleph Toolkit
*
* Copyright 1997, Brown University, Providence, RI.
*
*                         All Rights Reserved
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose other than its incorporation into a
* commercial product is hereby granted without fee, provided that the
* above copyright notice appear in all copies and that both that
* copyright notice and this permission notice appear in supporting
* documentation, and that the name of Brown University not be used in
* advertising or publicity pertaining to distribution of the software
* without specific, written prior permission.
*
* BROWN UNIVERSITY DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR ANY
* PARTICULAR PURPOSE.  IN NO EVENT SHALL BROWN UNIVERSITY BE LIABLE FOR
* ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/

package aleph;
import aleph.comm.CommunicationManager;
import aleph.thread.Call;
import java.io.Serializable;
import java.lang.Runnable;

/**
* The base class for remote functions. <p>
* Remote functions are like remote threads, except that they return a value.
* For example, a remote thread that returns a <code>String</code> could be written as follows.
* <p><blockquote><pre>
* class HelloThread extends RemoteFunction {
*   public Object run() {
*     return "Hello world!";
*   }
* }
</pre></blockquote>
* The following code creates a remote function, starts it at all PEs,
* and collects all return values.
* <p><blockquote><pre>
*  for (Enumeration e = PE.allPEs(); e.hasMoreElements(); )
*    thread.start((PE) e.nextElement(), join);
*  while(join.hasMoreElements())
*    System.out.println((String) join.nextElement());
* </pre></blockquote>
*
* @author Maurice Herlihy
* @date   May 1997
**/
abstract public class RemoteFunction implements Serializable {

  private static CommunicationManager cManager =
    CommunicationManager.getManager();

  /**
   * This method does all the work.
   **/
  public abstract Object run();

  /**
   * Start the thread at the indicated PE.
   * @param pe The PE where the thread should execute.
   **/
  public synchronized void start(PE pe) throws IllegalThreadStateException {
    start(pe, null);
  }
  /**
   * Start the thread at the indicated PE.
   * @param pe   The PE where the thread should execute.
   * @param join Stuff result object here.
   **/
  public synchronized void start(PE pe, Join join) {
    if (join != null)
      join.increment();
    Call call = new Call(join, this);
    try {
      cManager.send(pe, call);
    } catch (Exception e) {
      Aleph.panic(e);
    }
  }

}
TOP

Related Classes of aleph.RemoteFunction

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.