Corba非阻塞球

时间:2011-03-22 20:52:28

标签: java corba

我试图用java实现的Corba程序同时是另一个java程序的服务器和另一个java程序的客户端,所以我需要一个非阻塞的orb,它可以在一个单独的线程中运行(我有它在我的班级Orb_run): 但是我在设置Orb_run时遇到问题,我必须提供一个ORB对象,但如果我在orb上调用init方法,它将在这里创建一个新的bkocking对象,这是我服务器的代码,

public class machine {                                                                         
static int uid = 1;               
etat_machine etat;
static ORB  orb;   
static int token_uid  = 1;                                                                                                        


static void server(String[] args, int uid, int token_uid){         
   try {        
    //Instanciate Orb obj
    //orb = ORB.init(args, null); 

    //Instancier Orb_run
    Orb_Run orb_run = new Orb_Run(orb);

    POA poa = POAHelper.narrow(orb.resolve_initial_references("RootPOA"));
    poa.the_POAManager().activate();    

    machineImpl machine = new machineImpl(poa, uid, jeton_uid);        

    // create the object reference
    org.omg.CORBA.Object mach = poa.servant_to_reference(machine);

    try {
            String m1_ref = orb.object_to_string(mach);
            String refFile = "m1.ref";
            PrintWriter out = new PrintWriter(new FileOutputStream(refFile));
            out.println(m1_ref);
            out.close();
            } 
        catch (IOException ex) {
                System.err.println(
                        "Impossible d'ecrire la reference dans m1.ref");
                System.exit(1);
            }

        System.out.println("Le serveur m1 est pret ");

        // wait for requests
        orb_run.run();

    System.exit(0);
    }
    catch (Exception e) {
        System.out.println(e);
    }    

  //Client
  public static int client(int token_uid){

    orb.init(); 
   // Orb_Run orb_run = new Orb_Run(orb);
     String ior = null;

        try {
            String ref = "m2.ref";
            FileInputStream file = new FileInputStream(ref);
            BufferedReader in = new BufferedReader(new InputStreamReader(file));
            ior = in.readLine();
            file.close();
        } catch (IOException ex) {
            System.err.println("Impossible de lire fichier : '" +
            ex.getMessage() + "'");
            System.exit(1);
        }


        org.omg.CORBA.Object obj = orb.string_to_object(ior);

        if (obj == null) {
            System.err.println("Erreur sur string_to_object() ");
            throw new RuntimeException();
        }

 machine machine = machineHelper.narrow(obj); 

        if (machine == null) {
            System.err.println("Erreur sur narrow() ");
            throw new RuntimeException();
        }


        System.out.println("avant appel traitement_message ");

        jeton_uid = machine.traitement_message();

        System.out.println("le uid ds le jeton mnt"+ jeton_uid);

        return jeton_uid;
    }

}

我正在使用这个类在单独的线程中启动一个非阻塞的orb:

 public class Orb_Run extends Thread {

    public ORB  orb_;

   public Orb_Run(ORB  o) {
       orb_=o;
   }                                             
   public void run() {
      System.out.println("Le serveur est pret");
      orb_.run();
   }    }                                                                                      }

所以,如果你有一些如何做的提示,那就太棒了。

感谢。

3 个答案:

答案 0 :(得分:1)

我不知道如何使用Java中的标准API启动非阻塞ORB。你可以生成一个新线程来运行ORB,然后继续在主线程中工作吗?或者为客户端工作生成工作线程,并使用主线程进行ORB?

答案 1 :(得分:1)

不要执行orb_run.run();

由于此方法用于阻止当前线程....

答案 2 :(得分:0)

仍然在Java 7中,ORB.run()方法实际上执行无限等待; 工作线程独立于ORB.run()运行。 因此,根本不需要调用它,并且您具有出色的非阻塞ORB。